代码环境:jdk1.8.0_171,dubbo2.5.3,springboot1.5.3.RELEASE,spring4.3.8RELEASE
前天遇到了个很诡异的bug,有部分@Cacheable注解的缓存未生效,但@CachePut正常。网上查了下,全是什么类内部调用的,我这边不是此问题。比对了下生产环境的代码,发现新代码中,实现了ApplicationContextAware接口,去掉了这个实现,问题就解决了。
但原因呢?代码我就不上了,遇到这种问题的人,应该可以不要这种表达方式了。
原因是Dubbo。这个类是一个dubbo服务,dubbo的会对目标切面,但它与spring初始化时,对bean的aop没有配合好,导致dubbo发布出去的服务,没有spring的增强。阿里的东西很好用,但坑也很深,这个Bug要规避的话,就要改变思路,dubbo服务类想要使用spring上下文,还是老老实实地写个工具类吧。
另外,除了这个坑,dubbo还有另外一个坑,这俩坑太近了。dubbo服务类方法重载时,也会出现上述情况,原因就不想查了。还是老实点儿,别用方法重载了,反正改个方法名也不算什么。