RPC协议底层原理与实现

匿名 (未验证) 提交于 2019-12-03 00:26:01
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.序列化方式:
1.Hessian2Serialization、(默认)
2.DubboSerialization
3.JavaSerialization
4.JsonSerialization
RPC协议报文编码与实现详解



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


(注:相关源码参见 com.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框架为了更灵活扩展,其支持多种协议,用户只需要在 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)
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!