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-04-29:厨房里总共有 n 个橘子,你决定每一天选择如下方式之一吃这些橘子: 吃掉一个橘子。 如果剩余橘子数 n 能被 2 整除,那么你可以吃掉 n/2 个橘子。 如果剩余橘子数 n 能被
2022-04-29:厨房里总共有 n 个橘子,你决定每一天选择如下方式之一吃这些橘子: 吃掉一个橘子. 如果剩余橘子数 n 能被 2 整除,那么你可以吃掉 n/2 个橘子. 如果剩余橘子数 n 能被 ...
- 2021-12-22:回文子串。 给你一个字符串 s ,请你统计并返回这个字符串中 回文子串 的数目。 回文字符串 是正着读和倒过来读一样的字符串。 子字符串 是字符串中的由连续字符组成的一个序列。
2021-12-22:回文子串. 给你一个字符串 s ,请你统计并返回这个字符串中 回文子串 的数目. 回文字符串 是正着读和倒过来读一样的字符串. 子字符串 是字符串中的由连续字符组成的一个序列. ...
- 2021-08-16:回文对。给定一组 互不相同 的单词, 找出所有 不同 的索引对 (i, j),使得列表中的两个单词, words[i] + words[j] ,可拼接成回文串。
2021-08-16:回文对.给定一组 互不相同 的单词, 找出所有 不同 的索引对 (i, j),使得列表中的两个单词, words[i] + words[j] ,可拼接成回文串. 福大大 答案20 ...
- 在DevExpress的GridView的列中,使用RepositoryItemSearchLookUpEdit控件实现产品列表信息的展示和选择
有时候,我们为了方便,我们往往使用扩展函数的代码方式创建很多GridView的操作功能,如在随笔<在DevExpress中使用BandedGridView表格实现多行表头的处理>中介绍过多 ...
- 前端八股文everybody准备好了没
引言 由于最近比较忙活没时间学习新东西,现在得空想着能不能好好整理出一些有用的东西,让记忆深刻一点,免得到时候实习找工作面试的时候一问三不知,也希望大家能指正出错误和对大家有点帮助,一起进步,加油奥里 ...
- ChatGPT的原理与前端领域实践
一.ChatGPT 简介 ChatGPT的火爆 ChatGPT作为一个web应用,自22年12月发布,仅仅不到3个月的时间,月活用户就累积到1亿.在此之前,最快记录的保持者也需要9个月才达到月活1亿. ...
- 【Ubuntu22.04】配置静态IP地址和FTP服务
## 一.配置静态IP 1. 使用命令`ip a`查看当前网卡名称,Ubuntu22.04默认网卡为ens33: 是按照数据结构来组织.存储和管理数据的仓库,它的产生距今已有六十多年.随着信息技术和市场的发展,数据库变的无处不在:它在电子商务.银行系统等众多领域都 ...
- 韩顺平Spring体系化笔记(内含ioc,aop,动态代理等底层原理)
Spring Spring 核心学习内容 IOC.AOP. JdbcTemplate.声明式事务 1.Spring 几个重要概念 Spring 可以整合其他的框架(Spring 是管理框架的框架) S ...
- Cause: org.apache.ibatis.builder.BuilderException: Ambiguous collection type for property 'emps'. You must specify 'javaType' or 'resultMap'
错误原因 这个错误通常表示在解析 Mybatis 映射文件(Mapper XML)时出现了问题,可能的原因有两个: 集合属性缺少 javaType 或 resultMap 属性:该错误信息显示了 &q ...