Thrift 协议
功能描述
dubbo 当前支持的 thrift 协议是对 thrift 原生协议的扩展,在原生协议的基础上添加了一些额外的头部信息,例如服务名、magic number 等。2.3.0
及以上版本支持。
Thrift 是 Facebook 捐赠给 Apache 的 RPC 框架。
使用 dubbo thrift 协议还需要使用 thrift 的 idl 编译器编译生成相应的 java 代码,后续版本会在这方面做一些增强。
使用场景
适用于 SOA 标准 RPC 框架。
如何使用
依赖关系
从 Dubbo 3 开始,Thrift 协议不再嵌入 Dubbo 中,需要单独引入一个独立的 模块。
<dependency>
<groupId>org.apache.dubbo.extensions</groupId>
<artifactId>dubbo-rpc-native-thrift</artifactId>
<version>1.0.0</version>
</dependency>
<dependency>
<groupId>org.apache.thrift</groupId>
<artifactId>libthrift</artifactId>
<version>0.8.0</version>
</dependency>
所有服务共享一个端口
与原生 Thrift 不兼容
<dubbo:protocol name="thrift" port="3030" />
[dubbo 项目中的示例代码](https://github.com/apache/dubbo/tree/master/dubbo-rpc/dubbo-rpc-thrift/src/test/java/org/apache/dubbo/rpc/protocol /thrift)
Thrift 不支持空值,即:不能在协议中传递空值
上次修改时间:2023 年 2 月 22 日: 合并重构网站 (#2293) (4517e8c1c9c)