一、错误出现的场景:dubbo 的RPC远程调用,但是调用的服务总是提示“空指针异常”。
出现上述情况的原因:需要扫描的dubbo接口,dubbo 扫描service对象失败。
而造成失败的原因:
1、缺少dubbo 的jar 文件,
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>dubbo</artifactId>
<version>2.6.2</version>
<exclusions>
<exclusion>
<artifactId>spring</artifactId>
<groupId>org.springframework</groupId>
</exclusion>
</exclusions>
</dependency>
2、dubbo 扫描包路径配置错误。
检查提供者端 provider 的 application.properties中扫描包路径。
server.port=8886
dubbo.application.name=tmp-executor-provider
dubbo.registry.address=zookeeper://ip:port
dubbo.scan.base-packages=com.a.b.service
dubbo.server.port=22881
dubbo.protocol.port=7070
3、没有开启dubbo。需要在SpringBoot的启动类上加@EnableDubbo注解。
检查 消费者端** 和 提供者端 是否启用了dubbo。
@EnableDubbo
@SpringBootApplication(scanBasePackages = "com.a.**")
@ImportResource({"classpath*:spring*.xml"})
public class TmpExecutorApplication {
public static void main(String[] args) {
try{
SpringApplication.run(TmpExecutorApplication.class, args);
}catch(Exception e){
e.printStackTrace();
}
}
}
@ImportResource({"classpath*:spring*.xml"})
@EnableDubbo
@SpringBootApplication(scanBasePackages = {"com.a.**"})
public class TmpWebApplication {
public static void main(String[] args) {
try{
SpringApplication.run(TmpWebApplication.class, args);
}catch(Exception e){
e.printStackTrace();
}
}
}
参考链接:https://blog.csdn.net/zhouzhiwengang/article/details/68947823