『互联网架构』软件架构-dubbo协议底层原理与实现(44)

栏目: Java · 发布时间: 6年前

内容简介:相信通过上三次的文章,基本都了解了dubbo的一些套路,分布式如何做,注册中心,admin怎么玩的。其实对dubbo没有这么深入了解的老铁,也很多会使用dubbo。但是我们仅仅做到使用就完了吗?其实并不是的。我们角度仅仅不能满足使用,深层的意义就是满足底层远离和实现机制。####(一)RPC协议与使用场景

相信通过上三次的文章,基本都了解了dubbo的一些套路,分布式如何做,注册中心,admin怎么玩的。其实对dubbo没有这么深入了解的老铁,也很多会使用dubbo。但是我们仅仅做到使用就完了吗?其实并不是的。我们角度仅仅不能满足使用,深层的意义就是满足底层远离和实现机制。

『互联网架构』软件架构-dubbo协议底层原理与实现(44)

####(一)RPC协议与使用场景

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

『互联网架构』软件架构-dubbo协议底层原理与实现(44)

红色部分经过了一个线程池,RPC拿到数据后不能直接调用server的方法,必须要经过一个线程池。RPC协议服务端在进行反序列化,协议解码,网络传输,进行IO操作。如果IO线程去执行业务方法,业务方法本身需要做很多的操作,server的方法性能就非常的慢,导致RPC协议的IO线程,会被业务执行的逻辑堵塞,导致大量的客户端堵塞,最后链接挂了。

  • 协议的基本组成

『互联网架构』软件架构-dubbo协议底层原理与实现(44)

1.地址:服务提供者地址

2.端口:协议指定开放的端口

3.运行服务:

– netty

– mina

– RMI 服务

– servlet 容器(jetty、Tomcat、Jboss)

4.报文编码:协议报文编码

– http 报文编码

– Dubbo 报文编码

5.序列化方式:

– Hessian2Serialization

– DubboSerialization

– JavaSerialization

– JsonSerialization

####(二)协议报文编码

  • http协议

『互联网架构』软件架构-dubbo协议底层原理与实现(44)

『互联网架构』软件架构-dubbo协议底层原理与实现(44)

  • dubbo协议

    『互联网架构』软件架构-dubbo协议底层原理与实现(44)

协议的编解码过程

『互联网架构』软件架构-dubbo协议底层原理与实现(44)

『互联网架构』软件架构-dubbo协议底层原理与实现(44)

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 支持的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容器配置 数据包大小混合
thrift 与thrift RPC 实现集成,并在其基础上修改了报文头 长连接、NIO异步传输

关于RMI不支持防火墙穿透的补充说明:

原因在于RMI 底层实现中会有两个端口,一个是固定的用于服务发现的注册端口,另外会生成一个随机端口用于网络传输。这个随机端口就不能在防火墙中提前设置开放开。所以存在防火墙穿透问题 。

(五)协议的使用与配置

Dubbo框架为了更灵活扩展,其支持多种协议,用户只需要在 provider 应用中 配置即可 元素即可。

<!--

name: 协议名称 dubbo|rmi|hessian|http|

host:本机IP可不填,则系统自动获取

port:端口、填-1表示系统自动选择

server:运行服务 mina|netty|grizzy|servlet|jetty

serialization:序列化方式 dubbo|hessian2|java|compactedjava|fastjson

[详细配置参见dubbo 官网 dubbo.io](http://dubbo.io/books/dubbo-user-book/references/xml/dubbo-protocol.html)

-->

<dubbo:protocol name="dubbo" host="192.168.0.11" port="20880" server="netty"

serialization=“hessian2” charset=“UTF-8” />
  • 演示采用其它协议来配置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)

PS:dubbo很多协议都封装好了,直接xml已配置就ok了,其实并不复杂,对于底层实现其实就是RPC通信,就是socket没啥特别的。建议读下源码,debug跟踪下效果体会的更加明显。

>>原创文章,欢迎转载。转载请注明:转载自,谢谢!>>原文链接地址:上一篇:

已是最新文章


以上所述就是小编给大家介绍的《『互联网架构』软件架构-dubbo协议底层原理与实现(44)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Docker——容器与容器云

Docker——容器与容器云

浙江大学SEL实验室 / 人民邮电出版社 / 2015-9-1 / 89.00元

本书从实践者的角度,在讲解Docker高级实践技巧的同时,深入到源代码层次,为读者梳理出Docker容器技术和基于Docker的容器云技术(如Kubernetes)的实现方法和设计思路,帮助读者理解如何在实际场景中利用Docker解决问题并启发新的思考。全书包括两部分,第一部分深入解读Docker容器技术,包括Docker入门、架构总览、Docker容器核心原理解读,以及Docker高级实践技巧;......一起来看看 《Docker——容器与容器云》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具