解决dubbo的服务发布注解@service不能和事务注解不能共用的方案
最近在项目的开发中遇到了一个问题,就是服务提供方使用@service发布dubbo服务时候,服务消费方@Reference无法注入bean导致空指针异常的问题。分析原因为@service注解并没有将服务发布出去而导致的。所以解决问题的关键点在于如何将服务正确的发布出去。事务采用了aop技术,而aop默认采用的是基于JDK的动态代理(接口代理),所以在服务发布的时候无法确定使用接口类还是真实类,从而导致服务发布不成功。
故此,我们采用cglib代理,也就是子类代理的方式,需显式配置:<aop:aspectj-autoproxy proxy-target-class="true" />。此时又出现问题了,消费方调用服务时还是会出现空指针的问题。分析原因突然发现dubbo的@service注解不支持继承,也就是缺少了注解@Inherited。网上很多解决方案都是修改dubbo源码等等,个人认为并不可取,因为修改源码后需要将dubbo的jar上传到私服,然后重新下载依赖,过程比较繁杂,另一方面自己修改会不会引发其他的问题都是未知的。经过查阅资料发现dubbo的2.5.7及哟吼的版本修复了这个问题,所以直接使用2.5.7版本。
修改后测试发现依然会出现空指针的问题,这究竟是怎么回事呢?通过查看dubbo-admin管控台发现注册的服务竟然是spring的代理类,难怪找不到服务呢?因此在发布服务的时候直接指定服务接口就好了@Service(timeout = 5000,interfaceName="com.iservice.ByAgentCompanybillService")