大家好,又见面了,我是你们的朋友全栈君。
网络传输
、
序列化
等组件,其中RPC协议就指明了程序如何进行网络传输和序列化 。也就是说一个RPC协议的实现就等于一个非透明的RPC调用,如何做到的的呢?
客户端
服务端
地址:服务提供者地址;
端口:协议指定开放的端口;
运行服务:
netty(默认)
mina
RMI 服务
servlet 容器(jetty、Tomcat、Jboss)
报文编码(编解码):协议报文编码 。
注①:http 报文编码 。注②:Dubbo 报文编码
dubbo 序列化方式:
Hessian2Serialization
、(默认)
DubboSerialization
、
JavaSerialization
JsonSerialization
c
om.alibaba.dubbo.rpc.protocol.dubbo.DubboCodec
)
(源码来源于
dubbo2.5.8 )
89L
// 解码request
// 解码response
名称 | 实现描述 | 连接描述 | 适用场景 |
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|rmi|hessian|http|
mina|netty|grizzy|servlet|jetty
dubbo|hessian2|java|compactedjava|fastjson
host=”192.168.0.11″
port=”20880″ server=”netty”
hessian2”
charset= “
UTF-8” />
(
源码参见:com.alibaba.dubbo.rpc.protocol.dubbo.DubboProtocol
)
(
源码参见:
com.alibaba.dubbo.rpc.protocol.rmi.RmiProtocol)
(
源码参见:
com.alibaba.dubbo.rpc.protocol.http.HttpProtocol.InternalHandler)
(
源码参见:com.alibaba.dubbo.rpc.protocol.hessian.HessianProtocol.HessianHandler)
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/144624.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...