Mybatis-Plus+Nacos+Dubbo进行远程RPC调用保姆级教程
默认你已经看过我之前的教程了,并且拥有上个教程完成的项目,
之前的教程 https://www.cnblogs.com/leafstar/p/17638782.html
1.在bank1的pom文件中引入以下依赖
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-spring-boot-starter</artifactId>
<version>2.7.8</version>
</dependency>
2.使用dubboService一般是需要在Service层上进行,现在我们假设bank2的Bank2Service(还没有新建)提供dubboService
新建Bank2Service如下

代码如下
@Autowired
private User2Mapper user2Mapper;
@Override
public String addAmount(String name,int amount){
User user=null;
user = user2Mapper.selectOne(new LambdaQueryWrapper<User>().eq(StringUtils.isEmpty(name), User::getName, name));
if (user==null){
throw new RuntimeException("name为空或用户不存在");
}
user.setAmount(user.getAmount()+amount);
int i = user2Mapper.update(user, new LambdaQueryWrapper<User>().eq(User::getName, name));
return i>0?"成功":"失败";
}
这样我们的Bank2Service就同时提供RPC服务和本地服务了
3.接下来我们来模拟跨行转账
bank1的用户小明有1000元,向bank2的用户小红,原来有800元,转帐100元
我们现在已经写好了bank2的账户增加金额服务
接下来实现bank1的相关操作
bank1引入以下依赖
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-spring-boot-starter</artifactId>
<version>2.7.8</version>
</dependency> <dependency>
<groupId>com.example</groupId>
<artifactId>bank2</artifactId>
<version>0.0.1-SNAPSHOT</version>
<scope>compile</scope>
</dependency>
然后在bank1的controller里面添加bank2的远程服务
@DubboReference
private Bank2Service bank2Service;
在其controller里面添加以下接口
@GetMapping("/transfer")
public String transfer(String from,int amount,String to){
//默认参数不为空,不在校验
//from账户减少金额
User user = user1Mapper.selectOne(new LambdaQueryWrapper<User>().eq(User::getName, from));
user.setAmount(user.getAmount()-amount);
user1Mapper.update(user,new LambdaQueryWrapper<User>().eq(User::getName, from));
//to账户添加金额
bank2Service.addAmount(to,amount);
return "转账成功";
}
4.将两个项目重新运行
此时会报这个错误
@Service interfaceClass() or interfaceName() or interface class must be present!
我们需要把bank2的Service实现一个接口,利用这个接口进行RPC调用
bank2中添加以下接口

对服务进行稍微修改如下

接下来将bank1下controller原来写的
@DubboReference
private Bank2Service bank2Service;
改成
@DubboReference
private Bank2Interface bank2Service;
5.重启项目,报错如下
No registry config found or it's not a valid config! The registry config is: <dubbo:registry />
因为我们没有dubbo配置,接下来进行配置,在两个项目的配置文件中直接添加下列内容
dubbo:
#指定当前服务
# application:
# name: bank1
# qos-enable: false
#注册中心
registry:
protocol: nacos
address: 127.0.0.1:8848
#配置consumer启动时检查,check为false时,启动不检查,超时配置
#consumer中配置的是全局配置
# 幂等【操作多少次结果都是一样的,如:查询、删除、修改】,在设计系统是应该设置成幂等的
# 非幂等操作【和幂等对立,每次操作的结果不一样,如:新增,修改】,不能设置成重试
consumer:
check: false
#重试次数,不算第一次
retries: 3
timeout: 6000
# filter: logDubboConsumerFilter
#指定通信规则
protocol:
name: dubbo
port: 8806 #暴露服务端口(默认20880,不同的服务消费者端口不能重复)
threadpool: cached
#暴露服务
provider:
filter: -exception
loadbalance: leastactive
timeout: 6000
#监控中心
# monitor:
# protocol: registry
在bank2的启动类上加上@EnableDubbo注解

至此,项目基本搭建完成,重启项目,如果遇到端口错误,请往下看
nacos中出现下图代表服务注册成功

6.可能遇到一个非常奇怪的问题,bank1的nacos配置和bootstrap.yml配置的端口皆是8080,但是bank1就是不使用8080端口而是使用bank2的配置端口
可能是bootstrap文件会先于application文件加载。bank1的bootstrap.yml被bank2的application.yml覆盖。
解决办法,在bank1的bootstrap.yml同级目录下新建application.yml,在里面指定端口号即可。
在此也感谢某位不愿透露姓名的热心大哥的帮助。最后如下图

7.ok,重启项目,一切就绪。开始测试,调用下面get接口,也可以直接把网址放到浏览器中调用

观察数据库,确实小明成功减少100,小红增加了100,
8.至此,我们成功模拟了两个不同数据库下的微服务,不同网络下的微服务,通过dubbo进行RPC远程调用。
Mybatis-Plus+Nacos+Dubbo进行远程RPC调用保姆级教程的更多相关文章
- SSH以及ROS远程登录设置保姆级教程
本文用来实现在同一局域网内的两台计算机之间的相互通信,实现一台计算机登录到另一台计算机,本文基于SSH来实现. 1.SSH简介 Secure Shell(SSH)是由 IETF(The Interne ...
- Dubbo系列(三)dubbo的核心技术--RPC调用
dubbo的核心技术--RPC调用:分为俩部分RPC协议Protocol和方法调用Invoke: 一.RPC协议Protocol(Remote Procedure Call)远程过程调用协议 1.我们 ...
- 【原】通过Dubbo注解实现RPC调用
启动Dubbo服务有2个方式,1是通过xml配置,2是通过注解来实现,这点和Spring相似. 采用XML配置如下: <?xml version="1.0" encoding ...
- rabbitmq学习(四):利用rabbitmq实现远程rpc调用
一.rabbitmq实现rpc调用的原理 ·rabbitmq实现rpc的原理是:客户端向一个队列中发送消息,并注册一个回调的队列用于接收服务端返回的消息,该消息需要声明一个叫做correaltionI ...
- springboot+dubbo简单分布式RPC调用demo
使用springboot+dubbo搭建RPC入门案例 本文背景简述: 最近在学习公司的一套RPC框架,初步接触的时候感觉挺复杂的.但是知道其原理肯定是和dubbo很相似的,毕竟都是RPC框架嘛,只是 ...
- 自研发RPC调用框架
自主研发设计RPC远程调用框架,实现服务自动注册,服务发现,远程RPC调用,后续实现服务负载均衡 主要包括:客户端服务,服务端,服务发现,服务注册 github地址:https://github.co ...
- dubbo集成zookeeper rpc远程调用
注:下面使用dubbo依赖的是zookeeper注册中心,这里没有详细的介绍.在配置之前,请自行准备好zookeeper环境. 后续如果写zookeeper的配置会补放链接 添加Gradle依赖 co ...
- (八)整合 Dubbo框架 ,实现RPC服务远程调用
整合 Dubbo框架 ,实现RPC服务远程调用 1.Dubbo框架简介 1.1 框架依赖 1.2 核心角色说明 2.SpringBoot整合Dubbo 2.1 核心依赖 2.2 项目结构说明 2.3 ...
- SpringCloud Alibaba实战(12:引入Dubbo实现RPC调用)
源码地址:https://gitee.com/fighter3/eshop-project.git 持续更新中-- 大家好,我是老三,断更了半年,我又滚回来继续写这个系列了,还有人看吗-- 在前面的章 ...
- [转载] Dubbo实现RPC调用使用入门
转载自http://shiyanjun.cn/archives/341.html 使用Dubbo进行远程调用实现服务交互,它支持多种协议,如Hessian.HTTP.RMI.Memcached.Red ...
随机推荐
- 2022-08-19:以下go语言代码输出什么?A:equal;B:not equal;C:不确定。 package main import ( “fmt“ “reflect“ )
2022-08-19:以下go语言代码输出什么?A:equal:B:not equal:C:不确定. package main import ( "fmt" "refle ...
- 2021-02-28:给定一个整型数组arr,和一个整数num。某个arr中的子数组sub,如果想达标,必须满足:sub中最大值 – sub中最小值 <= num,返回arr中达标子数组的数量。
2021-02-28:给定一个整型数组arr,和一个整数num.某个arr中的子数组sub,如果想达标,必须满足:sub中最大值 – sub中最小值 <= num,返回arr中达标子数组的数量. ...
- 使用ONE.Abp快速开发微服务,再也不用加班了
项目背景 公司采用项目制工作方式,因此在不同项目上可能存在多个团队开发独立的代码库,但通用的基础设施却是相同的,这可能导致每个项目都需要编写相同的代码,并重复造轮子.更严重的是,每个项目都有自己的用户 ...
- 为什么 GPU 更适用于时域算法,而 CPU 更适用于频域算法?
对于懂电脑的人来讲,他们可以简单地区分出电脑的GPU和CPU的应用范畴及其优势,而今天我们要讨论的问题是"为什么 GPU 更适用于时域算法,而 CPU 更适用于频域算法?"在讨论这 ...
- JS逆向实战14——猿人学第二题动态cookie
声明 本文章中所有内容仅供学习交流,抓包内容.敏感网址.数据接口均已做脱敏处理,严禁用于商业用途和非法用途,否则由此产生的一切后果均与作者无关,若有侵权,请联系我立即删除! 目标网站 https:// ...
- rest framework 学习 序列化
序列化功能:对请求数据进行验证和对Queryset进行序列化 Queryset进行序列化: 1 序列化之Serializer 1 class UserInfoSerializ ...
- 从 pheatmap 无缝迁移至 ComplexHeatmap
pheatmap 是一个非常受欢迎的绘制热图的 R 包.ComplexHeatmap 包即是受之启发而来.你可以发现Heatmap()函数中很多参数都与pheatmap()相同.在 pheatmap ...
- 适用于Linux命令的10个R函数
由于微信不允许外部链接,你需要点击文章尾部左下角的 "阅读原文",才能访问文中链接. 这篇文章将介绍 10 个不同的 Linux 命令及其 R 实现方法. 如果您有兴趣学习更多 R ...
- 看看Angular有啥新玩法!手把手教你在Angular15中集成报表插件
摘要:本文由葡萄城技术团队于博客园原创并首发.葡萄城为开发者提供专业的开发工具.解决方案和服务,赋能开发者. Angular15新特性 Angular框架(以下简称"Angular" ...
- Python获取系统当前时间并进行类型转换
# 1.使用Python获取系统当前时间print('---------下面是方法1-----------')import timeprint(time.strftime('%Y-%m-%d %H:% ...