org.apache.dubbo.rpc.Protocol
SPI,提供自定义的 RPC 协议实现。在 通信协议 一章中,我们了解了 Dubbo 内置的几个核心 RPC 协议 dubbo
、rest
、和tri
以及它们的使用方式。本文讲解如何通过扩展 org.apache.dubbo.rpc.Protocol
SPI,提供自定义的 RPC 协议实现。
自定义一套私有协议有两种方式,第一种是对原有的协议进行包装,添加一些特定的业务逻辑。另外一种是完全自定义一套协议。前者实现简单,在dubbo
中也是有广泛的使用,比如:ProtocolFilterWrapper
, QosProtocolWrapper
, ProtocolListenerWrapper
等。后者实现相对复杂,但却具有最大的灵活性,比如 Dubbo 框架内置的协议 dubbo
、triple
协议都可以算作这种实现方式。
本示例的完整源码请参见 dubbo-samples-extensibility。除了本示例之外,Dubbo 核心仓库 apache/dubbo 以及扩展库 apache/dubbo-spi-extensions 中的众多 Protocol 实现,都可以作为扩展参考实现:
基于现有的dubbo
协议来实现自定义协议edubbo
。
通过对dubbo
协议进行包装来实现edubbo
协议。
在resources/META-INF/dubbo/org.apache.dubbo.rpc.Protocol
文件中添加如下配置:
在resources/META-INF/dubbo/org.apache.dubbo.rpc.Protocol
文件中添加如下配置:
在resources/application.properties
文件中添加如下配置:
在resources/application.properties
文件中添加如下配置:
以使用本地IDE的方式来运行任务,结果如下: