怎么去除网址(怎样去除图片上的网址)
609
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
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小时内删除侵权内容。