1.故障描述
我在SpringBoot项目中整合了Dubbo,用的是全注解方式使用。然后,在项目启动的时候运行的时候,有时候会报下面的异常
2019-05-28 14:05:08.134 [ERROR] [Saturn-DownOUTLETSBSTOrderJob-40-thread-1] com.alibaba.dubbo.registry.integration.RegistryDirectory [error-87] -Unsupported protocol hessian in notified url: hessian://10.10.90.22:8080/cms/com.yougou.pc.api.ICommodityBaseApiServiceanyhost=true&application=product-center&dubbo=2.5.3
由于篇幅原因,不贴完整的异常。
2.问题分析
对方提供的这个接口,确实在同一个版本对外暴露了dubbo协议的服务和hessian协议的服务。
我们作为消费者的时候,有时候消费的是dubbo协议提供的服务,有时候提供的是hessian协议提供的服务。
我们的配置文件中有配置dubbo,貌似是没有生效。
我们查看dubbo-admin这个里面,我们消费者地址字符串里面,就少了 protocol=dubbo 这样的配置。
3.解决方案
在每个使用dubbo的那个引用的地方,都做如下的配置(之前都没有加后面的parameters这个参数)
@Reference(version = "1.4", check = false, parameters = { "protocol", "dubbo" })
private IOrderApi orderApi;
4.优化建议
我们每次注册成为消费者之后,可以上dubbo-admin上面去看看注册的情况。