Dubbo基础理解

网友投稿 622 2022-05-29

Dubbo原理

什么是RPC

Dubbo框架

基本使用

基本底层原理

什么是RPC

维基百科定义:

远程过程调用(英语:Remote Procedure Call,缩写为 RPC)是一个计算机通信协议。该协议允许运行于一台计算机的程序调用另一个地址空间(通常为一个开放网络的一台计算机)的子程序,而程序员就像调用本地程序一样,无需额外地为这个交互作用编程(无需关注细节)。RPC是一种服务器-客户端(Client/Server)模式,经典实现是一个通过发送请求-接受回应进行信息交互的系统。如果涉及的软件采用面向对象编程,那么远程过程调用亦可称作远程调用或远程方法调用。

RPC协议:只是定义数据传输格式和传输方式,是一种应用层协议。

传输方式:有基于HTTP传输数据的RPC Over HTTP,也有基于TCP的RPC Over TCP等。

数据格式:双方协商定义,一般包括以下几点:

1、类名

2、方法名

3、参数类型(用来确定具体执行的方法,有方法重载)

4、参数值

Dubbo框架

dubbo是一种高性能、轻量级的开源Java RPC框架(最新官网称为服务框架),支持多种协议,默认使用dubbo协议,也可以使用HTTP协议等。

使用dubbo协议时,传输方式使用Netty;

使用HTTP协议时,传输方式使用Tomcat;

基本使用

Dubbo实现主要包括:服务提供者(provide)、服务消费者(Comsumer)、注册中心、监控中心组成

服务提供者

1、定义服务接口、提供接口实现类

// 接口(对外暴露的服务) public interface DemoService { String sayHello(String name); } // 接口实现类 public class DemoServiceImpl implements DemoService { public String sayHello(String name) { return "Hello " + name; } }

1

2

3

4

5

6

7

8

9

10

2、配置对外暴露服务(dubbo-demo-provide.xml,也可以使用注解的方式实现)

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

3、provide启动类

@SpringBootApplication public class ProviderApplication { public static void main(String[] args) { SpringApplication.run(ProviderApplication.class, args); } }

1

2

3

4

5

6

服务消费者

1、消费者配置(dubbo-consumer.xml)

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

Dubbo基础理解

2、Consumer 启动类

@SpringBootApplication public class ConsumerApplication{ public static void main(String[] args) throws Exception { SpringApplication.run(ConsumerApplication.class, args); DemoService demoService = (DemoService)context.getBean("demoService"); // 获取远程服务代理 String hello = demoService.sayHello("world"); // 执行远程方法 System.out.println( hello ); // 显示调用结果 } }

1

2

3

4

5

6

7

8

9

基本底层原理

Dubbo流程(粗略思路)

1、服务提供者提供接口、接口实现类(通过版本号区分多个实现类),对外暴露服务,通过共享注册中心注册服务(一般用zookeeper/redis)。

为什么要使用共享注册中心?

由于服务消费者和服务提供者是分别启动两个JVM(两个进程),所以需要使用共享注册中心。注册服务形式-服务名:List

2、启动Tomcat容器或Netty服务器

需要HTTP/Netty客户端,用来接收请求,需要HTTP/Netty服务端用来处理请求。

3、服务消费者读取用户配置(共享注册中心注册的服务)

服务路径每次从共享注册中心获取,消耗网络性能,所以先获取存放至本地注册中心缓存,数据保持同步。

数据保持同步:

4、定义数据传输类型(Invocation对象,序列化)

构造Invocation对象:指定参数列表、方法、参数、地址、接口

5、dubbo生成接口代理类放入spring容器,指定调用服务,发送请求

指定服务:考虑支持集群,在代理类中,从注册中心获取到的服务路径List有多个,使用负载均衡指定最终访问的服务。

为什么使用zookeeper/Redis作为共享注册中心?

在集群情况下会存在多个服务器,新增服务器注册中心需要添加服务路径,服务器挂了需要剔除服务路径,集群发生变化时zookeeper可以通过监听机制(Redis利用消费订阅机制)保证数据同步。

6、服务提供者接收处理请求

其他部分细节

多版本实现:对于多个实现类,服务提供者通过版本号区分(拼在服务名后),Dubbo中实现类使用@Service(version = “callback”)标识。

支持多个协议以及协议切换:可以使用工厂模式根据配置协议名使用指定协议。

新增协议:使用SPI机制。

集群集群变更:利用心跳机制监控集群,zookeeper可通过临时节点(Redis可通过过期时间节点)来实现心跳,这也是为什么注册中心使用zookeeper/Redis而不使用MySQL等的原因之二。

容错:服务调用失败可能是服务端调用失败也有可能是网络原因,Dubbo代理对象中捕获异常,做相关的容错处理。

Mock:服务未实现完,没必要进行网络请求,在发送之前可以做mock逻辑。

Dubbo TCP/IP

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Nginx搭建LNMP架构
下一篇:【云图说】第128期 小云妹之DDS实例安全基本操作
相关文章