RPC协议底层原理与实现

RPC协议基本组成
在一个典型RPC的使用场景中,包含了服务发现、负载、容错、 网络传输 序列化 等组件,其中RPC协议就指明了程序如何进行网络传输和序列化 。也就是说一个RPC协议的实现就等于一个非透明的RPC调用,如何做到的的呢?
Client 客户端
Server 服务端

协议基本组成:
    
1.    地址:服务提供者地址;
2.    端口:协议指定开放的端口;
3.    运行服务:
1.    netty(默认)
2.    mina
3.    RMI 服务
4.    servlet 容器(jetty、Tomcat、Jboss)
4.    报文编码(编解码):协议报文编码 。 注①:http 报文编码 。注②:Dubbo 报文编码
5.    dubbo 序列化方式:
1.    Hessian2Serialization 、(默认)
2.    DubboSerialization
3.    JavaSerialization
4.    JsonSerialization
RPC协议报文编码与实现详解



注①:http 报文编码
注②Dubbo 协议报文编码:


(注:相关源码参见 c om.alibaba.dubbo.rpc.protocol.dubbo.DubboCodec
协议的编解码过程:
 

Dubbo 协议编解码实现过程 (源码来源于 dubbo2.5.8 )
1、DubboCodec.encodeRequestData() 116L // 编码request
2、DecodeableRpcInvocation.decode() 89L // 解码request
3、DubboCodec.encodeResponseData() 184L // 编码response
4、DecodeableRpcResult.decode() 73L // 解码response
Dubbo中所支持RPC协议使用
名称实现描述连接描述适用场景
dubbo传输服务: mina, netty(默认), grizzy
序列化: dubbo, hessian2(默认), java, fastjson 自定义报文
单个长连接
NIO异步传输
1、常规RPC调用
2、传输数据量小 3、提供者少于消费者
rmi传输:java rmi 服务
序列化:java原生二进制序列化
多个短连接
BIO同步传输
1、常规RPC调用
2、与原RMI客户端集成 3、可传少量文件 4、不支持防火墙穿透
hessian传输服务:servlet容器
序列化:hessian二进制序列化
基于Http 协议传输,
依懒servlet容器配置
1、提供者多于消费者
2、可传大字段和文件 3、跨语言调用
http传输服务:servlet容器
序列化:http表单
依懒servlet容器配置1、数据包大小混合
thrift与thrift RPC 实现集成,并在其基础上修改了报文头长连接、NIO异步传输 
协议的使用与配置:

Dubbo框架为了更灵活扩展,其支持多种协议,用户只需要在 provider 应用中 配置即可 < dubbo:protocol > 元素即可。
<!--
name: 协议名称 dubbo|rmi|hessian|http|
host:本机IP可不填,则系统自动获取
port:端口、填-1表示系统自动选择
server:运行服务 mina|netty|grizzy|servlet|jetty
serialization:序列化方式 dubbo|hessian2|java|compactedjava|fastjson
-->
<dubbo:protocol name="dubbo" host="192.168.0.11" port="20880" server="netty"
serialization= hessian2” charset= UTF-8” />

#TODO 演示采用其它协议来配置Dubbo
dubbo 协议采用 json 进行序列化 ( 源码参见:com.alibaba.dubbo.rpc.protocol.dubbo.DubboProtocol )
采用RMI协议 ( 源码参见: com.alibaba.dubbo.rpc.protocol.rmi.RmiProtocol)
采用Http协议 ( 源码参见: com.alibaba.dubbo.rpc.protocol.http.HttpProtocol.InternalHandler)
采用Heason协议 ( 源码参见:com.alibaba.dubbo.rpc.protocol.hessian.HessianProtocol.HessianHandler)
  • 5
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Cloud Alibaba 包含了五个核心组件:Nacos、Sentinel、Dubbo、RocketMQ 和 Seata。下面分别介绍它们的底层实现原理。 1. Nacos Nacos 是阿里巴巴开源的服务发现、配置管理和动态 DNS 服务。它的底层实现原理是基于 Raft 算法实现的一致性协议,保证了数据的一致性和高可用性。Nacos 将注册中心、配置中心和命名服务合并在一个平台上,方便开发人员进行服务的管理。 2. Sentinel Sentinel 是阿里巴巴开源的微服务流量控制组件,提供实时监控、流量控制、熔断降级等功能。它的底层实现原理是基于令牌桶算法和滑动窗口算法实现的流量控制,通过统计请求的 QPS、RT、异常比例等指标,实现对服务的流量控制和熔断降级。 3. Dubbo Dubbo 是阿里巴巴开源的高性能 RPC 框架,提供了服务治理、负载均衡、容错机制等功能。它的底层实现原理是基于 Netty 实现的高性能网络通信,通过序列化、反序列化、协议编解码等技术实现跨语言的 RPC 调用。 4. RocketMQ RocketMQ 是阿里巴巴开源的分布式消息中间件,提供了高吞吐量、低延迟、可靠性等特性。它的底层实现原理是基于消息队列的发布/订阅模式实现的,通过消息队列的缓存、异步处理、水平扩展等技术实现高效的消息传递和处理。 5. Seata Seata 是阿里巴巴开源的分布式事务解决方案,提供了分布式事务的一致性协议和分布式事务管理器。它的底层实现原理是基于两阶段提交协议实现的,通过对分布式事务的预处理、提交和回滚等操作实现分布式事务的一致性和可靠性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值