使用Service描述的服务与springAop冲突导致服务无法暴露

来源:互联网 发布:角逐超高空知乎 编辑:程序博客网 时间:2024/06/08 20:13

     我参与的这个项目架构中采用了dubbo+zookeeper,为了线上排错方便用到了AOP拦截方法打印日志.项目是聚合工程,结构如下,当AOP拦截facade层时会出现服务注册不到dubbo上的情况.

                                                     

      出现这个问题的代码结构是:

@Servicepublic class demoFacadeImpl implements basicFacade{    //业务代码}
     原因分析:

     这个问题是和平哥一起研究的,平哥在群里问了别人之后了解到已经有人在dubbo的github上提出来这个issues,我们现在使用的是com.alibaba.dubbo.config.annotation.Service标签修饰该服务,出现这种情况的原因是配置有Spring aop的bean生成了代理对象,com.alibaba.dubbo.config.spring.AnnotationBean 这个类的postProcessAfterInitialization方法的Service service = bean.getClass().getAnnotation(Service.class); 这一行获取到的是由cglib代理出来的对象,所以无法得到@service 注解,导致服务未暴露.

    解决方案:

    由于使用的是注解的方式,spring AOP先执行的拦截后注册,导致服务不能暴露.我们修改了注册方式,不使用注解的方式,使用了配置文件的方式,在dubbo的配置文件中使用bean的方式注入.

原创粉丝点击