默认你已经看过我之前的教程了,并且拥有上个教程完成的项目,

之前的教程 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调用保姆级教程的更多相关文章

  1. SSH以及ROS远程登录设置保姆级教程

    本文用来实现在同一局域网内的两台计算机之间的相互通信,实现一台计算机登录到另一台计算机,本文基于SSH来实现. 1.SSH简介 Secure Shell(SSH)是由 IETF(The Interne ...

  2. Dubbo系列(三)dubbo的核心技术--RPC调用

    dubbo的核心技术--RPC调用:分为俩部分RPC协议Protocol和方法调用Invoke: 一.RPC协议Protocol(Remote Procedure Call)远程过程调用协议 1.我们 ...

  3. 【原】通过Dubbo注解实现RPC调用

    启动Dubbo服务有2个方式,1是通过xml配置,2是通过注解来实现,这点和Spring相似. 采用XML配置如下: <?xml version="1.0" encoding ...

  4. rabbitmq学习(四):利用rabbitmq实现远程rpc调用

    一.rabbitmq实现rpc调用的原理 ·rabbitmq实现rpc的原理是:客户端向一个队列中发送消息,并注册一个回调的队列用于接收服务端返回的消息,该消息需要声明一个叫做correaltionI ...

  5. springboot+dubbo简单分布式RPC调用demo

    使用springboot+dubbo搭建RPC入门案例 本文背景简述: 最近在学习公司的一套RPC框架,初步接触的时候感觉挺复杂的.但是知道其原理肯定是和dubbo很相似的,毕竟都是RPC框架嘛,只是 ...

  6. 自研发RPC调用框架

    自主研发设计RPC远程调用框架,实现服务自动注册,服务发现,远程RPC调用,后续实现服务负载均衡 主要包括:客户端服务,服务端,服务发现,服务注册 github地址:https://github.co ...

  7. dubbo集成zookeeper rpc远程调用

    注:下面使用dubbo依赖的是zookeeper注册中心,这里没有详细的介绍.在配置之前,请自行准备好zookeeper环境. 后续如果写zookeeper的配置会补放链接 添加Gradle依赖 co ...

  8. (八)整合 Dubbo框架 ,实现RPC服务远程调用

    整合 Dubbo框架 ,实现RPC服务远程调用 1.Dubbo框架简介 1.1 框架依赖 1.2 核心角色说明 2.SpringBoot整合Dubbo 2.1 核心依赖 2.2 项目结构说明 2.3 ...

  9. SpringCloud Alibaba实战(12:引入Dubbo实现RPC调用)

    源码地址:https://gitee.com/fighter3/eshop-project.git 持续更新中-- 大家好,我是老三,断更了半年,我又滚回来继续写这个系列了,还有人看吗-- 在前面的章 ...

  10. [转载] Dubbo实现RPC调用使用入门

    转载自http://shiyanjun.cn/archives/341.html 使用Dubbo进行远程调用实现服务交互,它支持多种协议,如Hessian.HTTP.RMI.Memcached.Red ...

随机推荐

  1. 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 ...

  2. 2021-02-28:给定一个整型数组arr,和一个整数num。某个arr中的子数组sub,如果想达标,必须满足:sub中最大值 – sub中最小值 <= num,返回arr中达标子数组的数量。

    2021-02-28:给定一个整型数组arr,和一个整数num.某个arr中的子数组sub,如果想达标,必须满足:sub中最大值 – sub中最小值 <= num,返回arr中达标子数组的数量. ...

  3. 使用ONE.Abp快速开发微服务,再也不用加班了

    项目背景 公司采用项目制工作方式,因此在不同项目上可能存在多个团队开发独立的代码库,但通用的基础设施却是相同的,这可能导致每个项目都需要编写相同的代码,并重复造轮子.更严重的是,每个项目都有自己的用户 ...

  4. 为什么 GPU 更适用于时域算法,而 CPU 更适用于频域算法?

    对于懂电脑的人来讲,他们可以简单地区分出电脑的GPU和CPU的应用范畴及其优势,而今天我们要讨论的问题是"为什么 GPU 更适用于时域算法,而 CPU 更适用于频域算法?"在讨论这 ...

  5. JS逆向实战14——猿人学第二题动态cookie

    声明 本文章中所有内容仅供学习交流,抓包内容.敏感网址.数据接口均已做脱敏处理,严禁用于商业用途和非法用途,否则由此产生的一切后果均与作者无关,若有侵权,请联系我立即删除! 目标网站 https:// ...

  6. rest framework 学习 序列化

    序列化功能:对请求数据进行验证和对Queryset进行序列化     Queryset进行序列化:         1  序列化之Serializer 1 class UserInfoSerializ ...

  7. 从 pheatmap 无缝迁移至 ComplexHeatmap

    pheatmap 是一个非常受欢迎的绘制热图的 R 包.ComplexHeatmap 包即是受之启发而来.你可以发现Heatmap()函数中很多参数都与pheatmap()相同.在 pheatmap  ...

  8. 适用于Linux命令的10个R函数

    由于微信不允许外部链接,你需要点击文章尾部左下角的 "阅读原文",才能访问文中链接. 这篇文章将介绍 10 个不同的 Linux 命令及其 R 实现方法. 如果您有兴趣学习更多 R ...

  9. 看看Angular有啥新玩法!手把手教你在Angular15中集成报表插件

    摘要:本文由葡萄城技术团队于博客园原创并首发.葡萄城为开发者提供专业的开发工具.解决方案和服务,赋能开发者. Angular15新特性 Angular框架(以下简称"Angular" ...

  10. Python获取系统当前时间并进行类型转换

    # 1.使用Python获取系统当前时间print('---------下面是方法1-----------')import timeprint(time.strftime('%Y-%m-%d %H:% ...