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