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)