RPC协议底层原理与实现「建议收藏」

RPC协议底层原理与实现「建议收藏」RPC协议基本组成在一个典型RPC的使用场景中,包含了服务发现、负载、容错、网络传输、序列化等组件,其中RPC协议就指明了程序如何进行网络传输和序列化。也就是说一个RPC协议的实现就等于一个非透明的RPC调用,如何做到的的呢?Client客户端Server服务端协议基本组成:    1.  地址:服务提供者地址;2.  端口:协议指定开放的端口;3.  运行服务:1.  netty(…

大家好,又见面了,我是你们的朋友全栈君。

RPC协议基本组成
在一个典型RPC的使用场景中,包含了服务发现、负载、容错、
网络传输

序列化
等组件,其中RPC协议就指明了程序如何进行网络传输和序列化 。也就是说一个RPC协议的实现就等于一个非透明的RPC调用,如何做到的的呢?
Client
客户端
Server
服务端
RPC协议底层原理与实现「建议收藏」
协议基本组成:

    
RPC协议底层原理与实现「建议收藏」

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 协议报文编码:

RPC协议底层原理与实现「建议收藏」


(注:相关源码参见
c
om.alibaba.dubbo.rpc.protocol.dubbo.DubboCodec
协议的编解码过程:
 
RPC协议底层原理与实现「建议收藏」

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)
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/144624.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 【推荐】Java内存管理系列文章

    勿在流沙筑高台,出来混迟早要还的。做一个积极的人编码、改bug、提升自己我有一个乐园,面向编程,春暖花开!谢谢你的阅读,如果您觉得这篇博文对你有帮助,请点赞或者喜欢,让更多的人看到!祝你每天开心愉快!不管做什么,只要坚持下去就会看到不一样!在路上,不卑不亢!博客首页 : http://blog.csdn.net/u010648555愿你我在人生的路上能都变成最好的自己,能…

    2022年2月28日
    35
  • python贪吃蛇最简单代码_用python写贪吃蛇

    python贪吃蛇最简单代码_用python写贪吃蛇一、前言之前版本很多小伙伴都觉得难度过高,另外也有粉丝问还能不能精简代码。所以这版降低了难度(由原来过关增加5km/h改为3.5KM/h),并通过反射代替IFELSE的写法,并删除了一些冗余的代码,将代码压缩到了71行(不必要的压缩代码是不建议的,这里压缩代码只是为了好玩)二、实现效果三、环境要求python3+pygame包安装命令:打开cmd输入:pipinstallpygame四、源码分享importpygameimportsysimportra

    2022年9月3日
    9
  • discuz php接口文档,Discuz二次开发技术文档[通俗易懂]

    discuz php接口文档,Discuz二次开发技术文档[通俗易懂]点评:Discuz二次开发基本知识总结,需要对discuz进行二次开发的朋友可以参考下。一)Discuz!的文件系统目录注:想搞DZ开发,就得弄懂DZ中每个文件的功能。a)Admin:后台管理功能模块b)Api:DZ系统与其它系统之间接口程序c)Archiver:DZ中,用以搜索引擎优化的无图版d)Attachments:DZ中,用户上传附件的存放目录e)Customavatars…

    2022年5月12日
    34
  • 多种时间格式字符串转换为Date对象「建议收藏」

    多种时间格式字符串转换为Date对象「建议收藏」maven引入包org.apache.commonscommons-lang33.8使用类org.apache.commons.lang3.time.DateUtils调用示例Datedate=DateUtils.parseDate(strDate,”yyyy-MM-dd”,”yyyy-MM-ddHH:mm:ss”,”yyyy/MM/dd”,”yy…

    2022年9月1日
    1
  • [Python图像处理] 一.图像处理基础知识及OpenCV入门函数[通俗易懂]

    [Python图像处理] 一.图像处理基础知识及OpenCV入门函数[通俗易懂]该系列文章是讲解PythonOpenCV图像处理知识,前期主要讲解图像入门、OpenCV基础用法,中期讲解图像处理的各种算法,包括图像锐化算子、图像增强技术、图像分割等,后期结合深度学习研究图像识别、图像分类应用。希望文章对您有所帮助,如果有不足之处,还请海涵~同时推荐作者的C++图像系列知识:[数字图像处理]一.MFC详解显示BMP格式图片[数字图像处理]二.MFC单文档分割窗…

    2022年10月15日
    0
  • 【转载】究竟啥才是互联网架构“高可用”

    【转载】究竟啥才是互联网架构“高可用”

    2021年11月20日
    42

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号