Thrift协议

Thrift协议

特性说明

当前 dubbo 支持的 thrift 协议是对 thrift 原生协议的扩展,在原生协议的基础上添加了一些额外的头信息,比如 service name,magic number 等。2.3.0 以上版本支持。

Thrift 是 Facebook 捐给 Apache 的一个 RPC 框架。

使用 dubbo thrift 协议同样需要使用 thrift 的 idl compiler 编译生成相应的 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 项目中的示例代码

Thrift 不支持 null 值,即:不能在协议中传递 null 值