基于rpc框架Dubbo实现的微服务转发实战
目录
rpc微服务模块
导入依赖
配置dubbo
注解 开启Dubbo
Dubbo的使用
特殊点 并没有使用 @ Reference 注入
微服务之间调用
可以选用Http 也可以Dubbo
我们 Dubbo 的实现需要一个注册中心
我作为一个服务的提供者 我需要把我的服务注册到注册中心去
调用方需要注册中心去把服务拉过来
注册中心是一个桥梁
我们之前是使用nacos作为配置中心的
rpc微服务模块
我们定义一个微服务模块叫rpc
导入依赖
<dependencies><!-- dubbo --><dependency><groupId>org.apache.dubbo</groupId><artifactId>dubbo-spring-boot-starter</artifactId></dependency><dependency><groupId>org.apache.dubbo</groupId><artifactId>dubbo-registry-nacos</artifactId></dependency><dependency><groupId>cn.hollis</groupId><artifactId>nft-turbo-base</artifactId></dependency></dependencies>
配置dubbo
一开始是一个检查 检查dubbo调用者是否存在
# Dubbo 配置的根节点,用于配置 Dubbo 框架的相关参数
dubbo:# 消费者配置,用于设置 Dubbo 服务消费者的相关参数consumer:# 服务调用超时时间,单位为毫秒。这里设置为 3000 毫秒,即 3 秒。# 若服务调用在 3 秒内未返回结果,将抛出超时异常timeout: 3000# 启动时是否检查提供者是否存在。设置为 false 表示启动时不检查,# 即使没有可用的提供者,消费者也能正常启动check: false# 协议配置,用于设置 Dubbo 服务通信所使用的协议protocol:# 协议名称,这里使用 Dubbo 原生协议进行服务调用name: dubbo# 协议端口号。设置为 -1 表示自动选择一个可用端口port: -1# 注册中心配置,用于配置 Dubbo 服务的注册与发现信息registry:# 注册中心地址,使用 Nacos 作为注册中心。# ${nft.turbo.nacos.server.url} 是一个占位符,实际值会从配置文件中获取address: nacos://${nft.turbo.nacos.server.url}# 注册中心的额外参数配置parameters:# Nacos 命名空间,用于隔离不同环境或项目的服务。# ${nft.turbo.dubbo.nacos.namespace} 是占位符,实际值从配置文件获取namespace: ${nft.turbo.dubbo.nacos.namespace}# Nacos 分组,用于对服务进行分组管理。# ${nft.turbo.dubbo.nacos.group} 是占位符,实际值从配置文件获取group: ${nft.turbo.dubbo.nacos.group}# 应用配置,用于设置当前 Dubbo 应用的相关信息application:# 应用名称,使用 Spring 应用的名称。# ${spring.application.name} 是占位符,实际值从 Spring 配置文件获取name: ${spring.application.name}# 是否启用 QoS(Quality of Service)功能。QoS 提供了一个命令行工具,# 可用于在运行时管理 Dubbo 应用,如查看服务列表、关闭服务等。设置为 true 表示启用qos-enable: true# QoS 是否允许外部 IP 访问。设置为 false 表示只允许本地 IP 访问 QoS 服务,# 增强了安全性,防止外部非法访问qos-accept-foreign-ip: false
我们使用命名空间给一系列调用中心归类 用于隔离不同环境或项目的服务
注解 开启Dubbo
@EnableDubbo
package cn.hollis.nft.turbo.rpc.config;import cn.hollis.nft.turbo.rpc.facade.FacadeAspect;
import org.apache.dubbo.config.spring.context.annotation.EnableDubbo;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;/*** Rpc 配置** @author hollis*/
@EnableDubbo
@Configuration
public class RpcConfiguration {@Beanpublic FacadeAspect facadeAspect() {return new FacadeAspect();}
}
我们接下来的引用
jar包 + 配置
Dubbo的使用
注册的话我们直接使用 @ DubboService 注解即可
这个注解说明的当前类不仅仅是一个 Service
而且要注册到 注册中心里面去 用Dubbo进行一个调用
当你要进行远程调用的时候
你可以使用 @ DubboReference 注解 去调用服务提供者
特殊点 并没有使用 @ Reference 注入
绕一把
package cn.hollis.nft.turbo.user.infrastructure;import cn.hollis.nft.turbo.api.chain.service.ChainFacadeService;
import org.apache.dubbo.config.annotation.DubboReference;
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;/*** 该配置类用于配置 Dubbo 服务引用,并将其注册为 Spring Bean。* 主要负责引用链服务接口,并在 Spring 容器中管理该服务实例。** @author Hollis*/
@Configuration
public class UserDubboConfiguration {/*** 使用 Dubbo 的 @DubboReference 注解引用远程的 ChainFacadeService 服务。* version = "1.0.0" 表示引用版本号为 1.0.0 的服务。* 该注解会将远程服务代理注入到当前字段中,以便在本地使用。*/@DubboReference(version = "1.0.0")private ChainFacadeService chainFacadeService;/*** 定义一个 Spring Bean,Bean 的名称默认为方法名 "chainFacadeService"。* @ConditionalOnMissingBean 注解表示只有当 Spring 容器中不存在名称为 "chainFacadeService" 的 Bean 时,* 才会执行此方法来创建该 Bean。* 该方法返回之前通过 @DubboReference 注解注入的 ChainFacadeService 实例,* 从而将 Dubbo 引用的服务注册为 Spring Bean,方便在 Spring 应用中使用。** @return ChainFacadeService 实例*/@Bean@ConditionalOnMissingBean(name = "chainFacadeService")public ChainFacadeService chainFacadeService() {return chainFacadeService;}
}
为了单测...
如果单元测试的话 还是会远程代理bean进行调用
是不能mock掉的
而autowired是可以进行mock的
@ MockBean就行
相关文章:

基于rpc框架Dubbo实现的微服务转发实战
目录 rpc微服务模块 导入依赖 配置dubbo 注解 开启Dubbo Dubbo的使用 特殊点 并没有使用 Reference 注入 微服务之间调用 可以选用Http 也可以Dubbo 我们 Dubbo 的实现需要一个注册中心 我作为一个服务的提供者 我需要把我的服务注册到注册中心去 调用方需要注册中心…...
matlab基于GUI实现水果识别
基于GUI实现水果识别系统,限一个图片内存在一种水果 图像处理是一种利用计算机分析图像以达到预期结果的技术。图像处理一般指数字图像处理,而数字图像指由工业相机、摄像机、扫描仪等设备捕捉到的二维数组,数组中的元素称为像素,…...
视频爬虫的Python库
1. 请求与网络库 最基础的 HTTP 请求库,用于发送 GET/POST 请求获取网页内容。 示例:获取视频页面 HTML 或 API 响应。 import requests response requests.get(https://example.com/video/123) aiohttp 异步 HTTP 请求库,适合大规模并发下…...

深度学习N2周:构建词典
🍨 本文为🔗365天深度学习训练营中的学习记录博客🍖 原作者:K同学啊 本周任务:使用N1周的.txt文件构建词典,停用词请自定义 1.导入数据 from torchtext.vocab import build_vocab_from_iterator from co…...
Qt多线程访问同一个数据库源码分享(基于Sqlite实现)
Qt多线程访问同一个数据库源码分享(基于Sqlite实现) 一、实现难点线程安全问题死锁风险连接管理问题数据一致性性能瓶颈跨线程信号槽最佳实践建议 二、源码分享三、测试1、新建一个多线程类2、开启多线程插入数据 一、实现难点 多线程环境下多个线程同时…...
多类别分类中的宏平均和加权平均
前言 在处理多类别分类问题时,宏平均(Macro-average)和加权平均(Weighted-average)是评估模型性能时常用的两种聚合指标。它们都能将每个类别的独立指标(如精确率、召回率、F1分数等)整合成一个…...
电子电路:什么是扩散电容?
PN结的电容效应主要有两种:势垒电容和扩散电容。势垒电容是由于耗尽层宽度变化引起的,而扩散电容可能和载流子的扩散过程有关。扩散电容通常出现在正向偏置的情况下,因为这时候多子注入到对方区域,形成电荷的积累。 当PN结正向偏置时,电子从N区注入到P区,空穴从P区注入到…...

贪心算法应用:装箱问题(FFD问题)详解
贪心算法应用:装箱问题(FFD问题)详解 1. 装箱问题概述 装箱问题(Bin Packing Problem)是计算机科学和运筹学中的一个经典组合优化问题。问题的描述如下: 给定一组物品,每个物品有一定的体积,以及若干容量相同的箱子,…...
机器学习的数学基础:假设检验
假设检验 默认以错误率为性能度量,错误率由下式给出: E ( f , D ) ∫ x ∼ D I I ( f ( x ) ≠ y ) p ( x ) d x E(f,\mathcal{D})\int_{\boldsymbol{x}\sim \mathcal{D}}\mathbb{II}(f(\boldsymbol{x})\ne y )p(\boldsymbol{x})\text{d}\boldsymbol{x…...
余氯传感器在智慧水务系统中如何实现IoT集成
现代余氯传感器(关键词:智能余氯监测、物联网水质传感器、LoRaWAN水监测)通过(关键词:Modbus RTU、4-20mA输出、NB-IoT传输)协议与SCADA系统对接,实现(关键词:远程氯浓度…...

操作系统学习(九)——存储系统
一、存储系统 在操作系统中,存储系统(Storage System) 是计算机系统的核心组成部分之一,它负责数据的存储、组织、管理和访问。 它不仅包括物理设备(如内存、硬盘),还包括操作系统提供的逻辑抽…...

服务器安装软件失败或缺依赖怎么办?
服务器在安装软件时失败或提示缺少依赖,是运维中非常常见的问题。这个问题大多发生在 Linux 云服务器环境,原因和解决方法也有共性。以下是详细说明和解决建议: 🧠 一、常见原因分析 问题类型描述🔌 软件源不可用服务器…...
linux nm/objdump/readelf/addr2line命令详解
我们在开发过程中通过需要反汇编查看问题,那么我们这里使用rk3568开发板来举例nm/objdump/readelf/addr2line 分析动态库和可执行文件以及.o文件。 1,我们举例nm/objdump/readelf/addr2line解析linux 内核文件vmlinux (1),addr2…...

006网上订餐系统技术解析:打造高效便捷的餐饮服务平台
网上订餐系统技术解析:打造高效便捷的餐饮服务平台 在数字化生活方式普及的当下,网上订餐系统成为连接餐饮商家与消费者的重要桥梁。该系统以菜品分类、订单管理等模块为核心,通过前台展示与后台录入的分工协作,为管理员和会员提…...

[10-2]MPU6050简介 江协科技学习笔记(22个知识点)
1 2 3 欧拉角是描述三维空间中刚体或坐标系之间相对旋转的一种方法。它们由三个角度组成,通常表示为: • 偏航角(Yaw):绕垂直轴(通常是z轴)的旋转,表示偏航方向的变化。 • 俯仰角&a…...
基于行为分析的下一代安全防御指南
一、技术原理演进 从特征匹配到行为建模传统防火墙依赖特征库匹配(如病毒指纹),而行为分析技术通过建立用户/设备/应用的正常行为基线(基线构建误差<0.8%),利用隐马尔可夫模型检测异常。微软Az…...
Redis持久化机制详解:RDB与AOF的深度剖析
一、为什么需要持久化? Redis作为内存数据库,数据存储在易失性内存中。持久化机制解决两大核心问题: 数据安全:防止服务器宕机导致数据丢失灾难恢复:支持数据备份与快速重建 二、RDB:内存快照持久化 ▶ …...
记录一次 apt-key curl导入失败的处理方式
在配置 Kubernetes APT 仓库的过程中,我们通常会执行如下命令来添加阿里云的 GPG 公钥: curl https://mirrors.aliyun.com/kubernetes/apt/doc/apt-key.gpg | apt-key add -但这次在某台新机器上执行时,出现了访问失败的问题。具体表现为 cu…...

Spring Boot 3.X 下Redis缓存的尝试(二):自动注解实现自动化缓存操作
前言 上文我们做了在Spring Boot下对Redis的基本操作,如果频繁对Redis进行操作而写对应的方法显示使用注释更会更高效; 比如: 依之前操作对一个业务进行定入缓存需要把数据拉取到后再定入; 而今天我们可以通过注释的方式不需要额外…...

【03】完整开发腾讯云播放器SDK的UniApp官方UTS插件——优雅草上架插件市场-卓伊凡
【03】完整开发腾讯云播放器SDK的UniApp官方UTS插件——优雅草上架插件市场-卓伊凡 一、项目背景与转型原因 1.1 原定计划的变更 本系列教程最初规划是开发即构美颜SDK的UTS插件,但由于甲方公司内部战略调整,原项目被迫中止。考虑到: 技术…...

C:\Users\中文名修改为英文名
C:\Users\中文名修改为英文名 背景操作步骤 背景 买了台新电脑,初始化好不知道啥操作把自己的登录用户名改成了中文,有些安装的软件看见有中文直接就水土不服了。 操作步骤 以下称中文用户名为张三。 正常登录张三用户 进入用户管理页面修改用户名&a…...
Web 架构相关文章目录(持续更新中)
文章目录 目录结构总结 目录结构 序号标题链接1Web 架构之数据库开发规范Web 架构之数据库开发规范2Web 架构之状态码全解Web 架构之状态码全解3Web 架构之会话保持深度解析Web 架构之会话保持深度解析4Web 架构之负载均衡会话保持Web 架构之负载均衡会话保持5Web 架构之攻击应…...
Redis 安装配置和性能优化
目录 简介 一、Redis 基础概念与优势 1.1 关系型与非关系型数据库对比 1.2 Redis 核心特性 二、Redis 部署 2.1 环境准备与源码安装 2.2 服务脚本配置与启动 三、Redis 配置参数 四、Redis 命令工具与常用操作 4.1 命令行工具(redis-cli) 4.2…...

购物商城网站 Java+Vue.js+SpringBoot,包括商家管理、商品分类管理、商品管理、在线客服管理、购物订单模块
购物商城网站 JavaVue.jsSpringBoot,包括商家管理、商品分类管理、商品管理、在线客服管理、购物订单模块 百度云盘链接:https://pan.baidu.com/s/10W0kpwswDSmtbqYFsQmm5w 密码:68jy 摘 要 随着科学技术的飞速发展,各行各业都在…...
PostgreSQL 安全纵深防御:从权限到加密
文章目录 PostgreSQL 安全纵深防御:从权限到加密 第一章:角色与权限体系 - PostgreSQL的安全基石 1.1 角色(ROLE)的本质与演进1.2 权限模型的三层架构1.3 GRANT/REVOKE 实战精解1.4 默认权限(DEFAULT PRIVILEGES&#…...
【美团技术团队】从实际案例聊聊Java应用的GC优化
【美团技术团队】从实际案例聊聊Java应用的GC优化 1. 美团技术团队优秀文章2. 绪论 1. 美团技术团队优秀文章 Java NIO浅析 https://tech.meituan.com/2016/11/04/nio.html红黑树深入剖析及Java实现 https://tech.meituan.com/2016/12/02/redblack-tree.htmlJava 8系列之重新认…...

在word中点击zotero Add/Edit Citation没有反应的解决办法
重新安装了word插件 1.关掉word 2.进入Zotero左上角编辑-引用 3.往下滑找到Microsoft Word,点重新安装加载项...

整合swagger,以及Knife4j优化界面
因为是前后端项目,需要前端的参与,所以一个好看的接口文档非常的重要 1、引入依赖 美化插件其中自带swagger的依赖了 <dependency><groupId>com.github.xiaoymin</groupId><artifactId>knife4j-openapi3-spring-boot-starter&…...

Unity | AmplifyShaderEditor插件基础(第四集:简易shader)
一、👋🏻前言 大家好,我是菌菌巧乐兹~本节内容主要讲一下,第一个用ASE的shader。 我们用通用的光照模版吧。(universal-通用/Lit-光照) 通用的光照模版 如果你尝试建设了,会发现Universal这个…...
【安全攻防与漏洞】量子计算对HTTPS的威胁:后量子密码学进展
⚛️ 一、量子计算对HTTPS的核心威胁 Shor算法破解非对称加密 Shor算法可高效分解大整数(破解RSA)和计算椭圆曲线离散对数(破解ECC),而HTTPS依赖的TLS握手阶段依赖RSA/ECC进行密钥交换和身份验证。一旦实用化量子计算…...