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

之前的教程 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-02-11:单词缩写。 给定一个由n个不重复非空字符串组成的数组,你需要按照以下规则为每个单词生成最小的缩写。 初始缩写由起始字母+省略字母的数量+结尾字母组成。 若存在冲突,亦即多于一个单

    2022-02-11:单词缩写. 给定一个由n个不重复非空字符串组成的数组,你需要按照以下规则为每个单词生成最小的缩写. 初始缩写由起始字母+省略字母的数量+结尾字母组成. 若存在冲突,亦即多于一个单 ...

  2. weekday

    # 模块中的方法weekday()# 可用于检索星期几,结果返回0 - 6# 之间的整数,用来代表"星期一"到"星期日".# self.wt_w = self. ...

  3. linux LVM和磁盘配额

    目录 一.LVM原理 二.LVM的命令 三.创建lvm过程 四.扩容 五.磁盘配额 一.LVM原理 lvm是逻辑卷管理,可以让用户动态管理磁盘,不用考虑物理磁盘的问题,可以快速扩充磁盘大小,可以不用一 ...

  4. MySQL中字符串查询效率大比拼

    背景 最近有个同事对字符串加索引,加完后,发现多了个奇奇怪怪的数字执行的SQL如下: alter table string_index_test add index `idx_name` (`name ...

  5. Java革命性ORM框架之快速上手的Jimmer

    Jimmer是一款革命性的ORM框架,它的目标是提供一个简单易用的API,帮助开发人员更加轻松地操作数据库.Jimmer使用了Java 8的新特性,如Lambda表达式和Stream API,使得代码 ...

  6. ENVI5.6 安装教程,新手入门(超详细)附安装包和常见问题

    ENVI是一个完整的遥感图像处理平台,广泛应用于科研.环境保护.气象.农业.林业.地球科学.遥感工程.水利.海洋等领域.目前ENVI已成为遥感影像处理的必备软件,包含辐射定标.大气校正.镶嵌裁剪.分类 ...

  7. 用 Python + turtle 模块绘制五星红旗

    用 Python 绘制五星红旗 在这个代码示例中,我将介绍如何使用 Python 的 turtle 模块绘制五星红旗.turtle 模块是一个图形库,可以轻松地在 Python 中实现简单的绘图功能. ...

  8. Hello Welcome to my blog!

    Hello Welcome to my blog!

  9. JDBC详解(韩顺平教程)

    JDBC 一.原理示意图 二.前提步骤 IDEA导入MySQL的jdbc驱动,并操作数据库 - 打点 - 博客园 (cnblogs.com) 三.JDBC编写步骤: 用法1: package Hsp. ...

  10. 5 大数据实战-hive实战分析

    1 内部表 Show databses; Use hive_data; 1.1 创建内部表 CREATE TABLE SOGOUQ2(DT STRING,WEBSESSION STRING,WORD ...