现在将网上的方法总结一下

方法一:.https://blog.csdn.net/u011294519/article/details/81810631

dubbo-provider.xml:提供者先扫描spring框架,完成spring部分的扫描,然后将为dubbo框架提供服务;消费者部分相反,先扫描dubbo服务,后扫描spring部分~

1. 背景

使用@Reference注解实现消费者调用服务端代码,调用报错NullPointerException,如图:

注意:如果你的服务端没有注册到dubbo,客户端在调用时也会出现NullPointerException报错,所以可以先到dubbo-admin去看下服务端是否已经正常注册。

dubo-admin安装方式可参照:

https://blog.csdn.net/u011294519/article/details/81712601

2. 服务端代码

因为只是写一个小demo,代码逻辑十分简单

2.1. 服务端接口

2.2. 服务端接口实现类

注意:这里的@Service注解需要使用com.alibaba.dubbo.config.annotation.Service。

2.3. 服务端dubbo配置文件

3. 客户端代码

3.1.接口

3.2. 测试接口

3.3. 配置文件

4. Dubbo-admin结果

到这里为止看上去都很正常,但是只要客户端调用服务端方法就报NullPointerException。

5. 解决方法

网上找了很多方法,但是都不能解决问题,后来想到有没有可能是SpringMVC的包扫描影响了dubbo的注解扫描,然后尝试着将dubbo的包扫描配置单独抽出来,放在SpringMVC配置的最上面,果然问题解决。如图:

然后把dubbo配置中的这个去掉,问题解决。

但是我的问题没有解决

方法二:https://blog.csdn.net/yuzhibo0924/article/details/80091646

最近开发公司项目,遇到了dubbo服务为空的情况,现在把出现的情况做个简单的总结:

dubbo为空会报空指针异常!

1.第一种情况:引用有误,也就是再注入dubbo服务的时候,使用@Reference注解的时候,引用的并不是ali的dubbo,所以一直引入的都是错误的。导致注入为null;

这种情况比较常见,因为粗心大意导致import 文件错误,只需要认真检查。就可以找出问题所在。

2.第二种情况:引用很正常,使用的是@Reference的注解,也是ali的dubbo。

但具体情况是:(我本人的情况)自己在本地测试,代码流程完全没有任何问题。于是将代码提交到开发环境进行代码测试,一切正常。然后提交测试,交由测试进行代码测试。发现问题,最后定位到dubbo服务为空。引用没有问题,那是什么原因导致的dubbo服务为null呢?后来经过同事指导,才明白问题所在。在同一个项目中,A服务引用B服务(都是注册到dubbo上的),在项目部署发布的时候,无法判断是哪个服务先注册到dubbo上的。所以在A服务中引用B服务,而且通过dubbo的方式注入,极有可能会产生服务注入为null的情况。那么此时在A服务中引用B服务,就可以使用spring框架带的@Autowired的注入方式,将B服务引用进来。这样就可以完美解决这个问题。

但是我的问题依旧没有解决

方法三:原因是包名不一致,包名不一致会导致提供者和消费者不在一个节点上,这样消费者永远不会获得值!!

但是也没有解决我的问题

方法四:

项目设计之初是想分布式部署,所以分了客户端,和服务端。经过测试发现真的是程序启动的顺序问题。

之前都是先启动server服务端,然后在启动client端的,但是这两天项目有点赶,调试的时候,想快点启动,所以几乎是同时启动server和client程序,甚至client先启动,然后就导致了本文标题的错误。之后我就老老实实的先启动server程序,在启动client。
---------------------
原文:https://blog.csdn.net/likawei1314/article/details/80757687
方法五

@SpringBootApplication之前添加注解@EnableDubboConfig就可以解决了,确保优先加载dubbo配置。

dubbo 使用zookeeper 出现 Dubbo客户端调用报错NullPointerException的更多相关文章

  1. CFX客户端调用报错

    Exception in thread "main" javax.xml.ws.soap.SOAPFaultException: Unmarshalling Error: unex ...

  2. 【DUBBO】zookeeper在dubbo中作为注册中心的原理结构

    [一]原理图 [二]原理图解释 流程:1.服务提供者启动时向/dubbo/com.foo.BarService/providers目录下写入URL2.服务消费者启动时订阅/dubbo/com.foo. ...

  3. 【技术贴】webservice cxf2 客户端动态调用报错No operation was found with the name

    No operation was found with the name xxx 出错原因是因为发布服务的接口所在包路径和此接口实现类包路径不一致,比如你的服务接口可能放在了包com.x.interF ...

  4. springboot多模块项目下,子模块调用报错:程序包xxxxx不存在

    今天在用springboot搭建多模块项目,结构中有一个父工程Parent  一个通用核心工程core 以及一个项目工程A 当我在工程A中引入core时,没有问题,maven install正常 当我 ...

  5. jmeter 启动jmeter-server.bat远程调用报错: java.io.FileNotFoundException: rmi_keystore.jks (系统找不到指定的文件。)

    1.找到apache-jmeter-5.0\bin\jmeter.properties 2.修改server.rmi.ssl.disable=true (记得去除server.rmi.ssl.disa ...

  6. bug:进程可调用函数而子线程调用报错

    在调试摄像头时遇到问题:在主进程里调用下述函数能够成功,但在子线程里创建时总是失败,错误打印为 sched: RT throttling activated. UniqueObj<OutputS ...

  7. Windows平台下使用CodeBlocks+GCC编译器生成动态dll,C#调用报错

    报无法加载dll错误,解决方法: 1) 编译选择设置成x86,即-m322) 必须在c#程序目录下加上libgcc_s_dw2-1.dll

  8. artTemplate--使用artTemplate时,由于json对象属性有特殊格式 导致调用报错artTemplate,syntax error,Template Error

    我们首先看下面的代码 data = { "siteName" : "西部云谷二期17", "PM10" : "10017" ...

  9. protobuf接口调用报错:java.nio.charset.MalformedInputException: Input length = 1

    使用protobuf定义的接口api发起http请求报错,日志如下: [-- ::] DEBUG AbstractPool: - server updated, node=, server={ nod ...

随机推荐

  1. Js的reduce()方法

    Js 数组reduce()方法应用一个函数针对数组的两个值(从左到右),以减至一个值. 语法:array.reduce(callback[, initialValue]) 参数说明: 1)callba ...

  2. PHP中使用 fsockopen curl 模拟异步处理

    PHP它最大缺点就是无法实现多线程管理,其程序的执行都是从头到尾,按照逻辑一路执行下来,不可能出现分支,这一点是限制php在主流程序语言中往更高级的语言发展的原因之一. 在PHP中我们有的时候其实希望 ...

  3. 关于火狐和IE下href="javascript:void(0)"兼容性的问题

    今天在开发中发现,使用如下方式的链接.在Chrome中点击后行为符合预期,但在IE下会新开标签卡(根据参考资料,Firefox中有相同问题). 经过排查,发现是href="javascrip ...

  4. 高效使用VSCode的9点建议

    在开源 IDE 市场,最近几年 Visual Studio Code(简称 VSCode)越来越流行.自从 2015 年对外发布后,根据 2018 年 Stack Overflow 的调查报告,有 3 ...

  5. 自然语言处理(nlp)比计算机视觉(cv)发展缓慢,而且更难!

    https://mp.weixin.qq.com/s/kWw0xce4kdCx62AflY6AzQ 1.  抢跑的nlp nlp发展的历史非常早,因为人从计算机发明开始,就有对语言处理的需求.各种字符 ...

  6. EBGP在非直连网络时,需要配置ebgp的最大跳数,否则无法建立非直连的EBGP邻居

    结论: 1.默认情况下,EBGP只能在物理直连的路由器之间建立邻居. 2.要想配置非直连设备间的BGP邻居,必须加配置. 组网图: 抓包: 1.默认情况下,EBGP邻居之间的BGP报文的TTL为1. ...

  7. spring学习总结——装配Bean学习三(xml装配bean)

    通过XML装配bean Spring现在有了强大的自动化配置和基于Java的配置,XML不应该再是你的第一选择了.不过,鉴于已经存在那么多基于XML的Spring配置,所以理解如何在Spring中使用 ...

  8. Spark dataframe【KV格式】模拟实现Map操作

    代码实现 // rdd转化为df[kv格式]val df = sqlContext.createDataFrame(check_data_type, structType) .select(" ...

  9. python smtplib发email

    #!/usr/bin/env python #coding: utf-8 import smtplib from email.mime.text import MIMEText from email. ...

  10. SQLServer之创建视图

    视图定义 视图是一个虚拟的表,是一个表中的数据经过某种筛选后的显示方式,视图由一个预定义的查询select语句组成. 使用SSMS数据库管理工具创建视图 1.连接数据库,选择数据库,展开数据库-> ...