当前dubbo支持的thrift协议是对thrift原生协议的扩展,在原生协议的基础上添加了一些额外的头信息,比如服务名称,魔术数字等。
使用dubbo thrift协议同样需要使用thrift的idl编译器编译生成相应的java。
依赖
<dependency>
<groupId>org.apache.thrift</groupId>
<artifactId>libthrift</artifactId>
<version>0.8.0</version>
</dependency>
配置
所有服务公用一个端口
<dubbo:protocol name="thrift" port="3030" />
常见问题
节俭不支持空值,即:不能再协议中传递空值
ThriftProtocol也是提供了export和refer对外暴露服务和引用服务两个功能:
(1)export:暴露服务,通过netty、mina或者grizaly对外暴露tcp服务
//通过dubboExport中提供的netty、mina或grizaly对外暴露tcp协议
public <T> Exporter<T> export(Invoker<T> invoker) throws RpcException {
// can use thrift codec only
URL url = invoker.getUrl().addParameter(Constants.CODEC_KEY, ThriftCodec.NAME);
// find server.
String key = url.getAddress();
// client can expose a service for server to invoke only.
boolean isServer = url.getParameter(Constants.IS_SERVER_KEY, true);
if (isServer && !serverMap.containsKey(key)) {
serverMap.put(key, getServer(url));
}
// export service.
key = serviceKey(url);
DubboExporter<T> exporter = new DubboExporter<T>(invoker, key, exporterMap);
exporterMap.put(key, exporter);
return exporter;
}
(2)refer:引用服务,与服务提供者建立长连接进行服务引用
//通过ThriftInvoker中提供的netty、mina或grizaly通过tcp协议与服务提供者建立连接
public <T> Invoker<T> refer(Class<T> type, URL url) throws RpcException {
ThriftInvoker<T> invoker = new ThriftInvoker<T>(type, url, getClients(url), invokers);
invokers.add(invoker);
return invoker;
}