如题,我们要使用Spring Boot和RabbitMQ实现RPC远程调用,那么首先要了解RPC。RPC,即Remote Procedure Call Protocol 远程过程调用协议,在大型的公司,系统一般都是由大大小小的服务构成,不同的团队维护不同的代码,部署在不同的机器。但是在做开发时候往往要用到其它团队的方法,因为已经有了实现。但是这些服务部署不同的机器上,想要调用就需要网络通信,这些代码繁琐且复杂,一不小心就会写的很低效。RPC协议定义了规划,其它的公司都给出了不同的实现。而现在我们不使用其他公司的实现,直接使用消息中间件RabbitMQ进行实现。 现在有这样的一个业务场景,在一个商城系统中,用户在订单微服务中购买商品成功之后会给用户相应的积分,而积分系统是另外一个微服务,两个微服务之间的调用之前是使用ribbon+eureka+feign进行调用的,现在我们使用这样的逻辑,将它改造成使用RabbitMQ进行RPC调用:
1.创建工程
创建两个微服务工程order和integral,引入相同的依赖:
[XML] 纯文本查看 复制代码
01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
|
< parent >
< groupId >org.springframework.boot</ groupId >
< artifactId >spring-boot-starter-parent</ artifactId >
< version >2.0.1.RELEASE</ version >
</ parent >
<!-- 管理依赖 -->
< dependencyManagement >
< depe
|