问题:在项目中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”)