@Reference注解注入失败的问题
问题:在项目中dubbo服务消费者在消费的时候会遇到@Reference注解注入失败的问题
先去看看dubbo配置文件
最重要的就是看一下自己dubbo的配置文件,扫描的包路径,我是创建了一个新的config包,使用了@reference,由于没有在配置文件上包扫描,所以运行为空
排查思路
- 服务是否正常启动(服务提供者先启动) 可以通过日志输出查看是否启动正常,在这里不过多的描述。
- @reference @service注解是不是dubbo的注解 @Reference注解:com.alibaba.dubbo.config.annotation.Reference @Service注解:com.alibaba.dubbo.config.annotation.Service
- zk是否正常 查看zk状态:systemctl status zk
若不正常,可以查看zk是否有日志损坏问题,重启zk。
- 是否成功注册 进入zk的bin目录下执行 ./zkCli.sh ls /dubbo/{XX}/providers 查看服务提供者是否成功注册 ls /dubbo/{XX}/consumers 查看服务消费者者是否成功注册 如果为[]说明没有成功注册 如果没有成功注册可以检查配置配置文件/注解的配置、检查端口、检查版本号等。
- 是否注入成功 如果以上均没有问题,就需要考虑是否注入成功的问题了。 我就是在这个地方发现的问题。 我的配置文件配置了dubbo.scan.basePackages 扫描到了对应的层(楼主是controller层)但是没有注入成功。 通过查看spring bean的注入顺序得知,controller是在spring容器初始化所有bean之后,初始化springMVC的时注入的,所以导致@Reference注解无效。 解决办法:在Controller类(或其他类)上加一个类注解 @DubboComponentScan(basePackages = “该类的包名 如:com.halon.controller”)