使用注解方式实现Dubbo搭建,解决消费者调用接口出现空指针异常以及事务等问题
2017-08-25 18:56
831 查看
PS:最上边ps,此贴终结,更新最新版的dubbo,一切问题迎刃而解!
最近接手了一个对之前项目进行重构的任务,使用dubbo+maven进行整合,并且将hibernate全部改成JdbcTemplate。主流还是使用springMVC+spring进行开发。
按照之前经验,使用xml配置方式,发布服务到zookeeper,成功运行,但是,我们想做的是使用dubbo的service注解进行发布,遇到点问题,所以总结一下。
主要问题有三个比较重要的问题:
1. 使用dubbo的com.alibaba.dubbo.config.annotation.Service注解来注入服务提供者;
2. 使用@Reference来注册消费者时,调用服务时出现空指针异常;
3. 使用com.alibaba.dubbo.config.annotation.Service导致事务失效;
第一个问题解决方案
在spring的xml文件中配置如下即可,
<!-- 提供方应用信息,用于计算依赖关系 -->
<dubbo:applicationname="${zookeeper.name}"/>
<!-- 使用zookeeper注册中心暴露服务地址 -->
<dubbo:registryprotocol="zookeeper"address="${zookeeper.address}"/>
<!-- 用dubbo协议在20880端口暴露服务
-->
<dubbo:protocolname="dubbo"port="${zookeeper.port}"/>
<!-- 声明需要暴露的服务接口 <dubbo:serviceinterface="com.cxb.uc.test.ITestService2"
ref="testService2Impl" />-->
<!-- 使用注解方式暴露接口 -->
<dubbo:annotationpackage="com.cxb.uc"/>
配置文件大同小异,都是这样,基本没什么问题,但是在使用@Service注解时出现了一个奇怪的问题,使用DubboAdmin时,全部都是代理对象的名字,一堆proxy。最后在如下解决:
@Service(interfaceName="com.test.ITestService")
直接使用iterfaceName命名服务名。
到此第一个问题告一段落。
第一个问题解决好后,便觉的没什么其他问题了。
项目发布很正常,一切都和预=预期一样正常,可是到测试接口的时候,遇到第二个问题,一直会出现空指针异常:
网上解决方法很多,尝试了好多,最终在配置文件实现,就是在spring的核心xml文件中配置一遍dubbo的相关配置,同时在springMVC的xml的最前再边配置一遍,原因就是,spring的注解扫描会导致dubbo失效,(具体原因没有细究,这里留下疑问)。配置如下:
Context的xml配置
<dubbo:applicationname="${zookeeper.name}"/>
<!-- 使用zookeeper注册中心暴露服务地址 -->
<dubbo:registry
89dd
protocol="zookeeper"address="${zookeeper.address}"/>
<!-- 要引用的服务 -->
<dubbo:annotation/>
<!-- 启用spring mvc注解 -->
<context:annotation-config/>
springMVC配置文件中将上述也放到最前边就可以解决。
第三个问题是在添加事务管理的时候发现的,解决方案,在该博客发现
http://jhaij.iteye.com/blog/2171723
当加入事务后,spring bean 事务代理, dubbo的 AnnotationBean 扫描 类执行下面的代码的时候就获取不到对应的注解,也就发布不了服务:
Java代码
Service service =bean.getClass().getAnnotation(Service.class);
if (service != null) {
因为被cglib或者java proxy 代理的类获取不到该dubbo的service注解.
我按照方法,直接去maven库中,将加上java.lang.annotation.Inherited 注解的Service.class替换进去。实际上我在查看github上的最新dubbo源码时,这个注解已经添加了,不知道为啥不发不到Maven库中。
以上就是这次简陋的不谨慎的总结。
最近接手了一个对之前项目进行重构的任务,使用dubbo+maven进行整合,并且将hibernate全部改成JdbcTemplate。主流还是使用springMVC+spring进行开发。
按照之前经验,使用xml配置方式,发布服务到zookeeper,成功运行,但是,我们想做的是使用dubbo的service注解进行发布,遇到点问题,所以总结一下。
主要问题有三个比较重要的问题:
1. 使用dubbo的com.alibaba.dubbo.config.annotation.Service注解来注入服务提供者;
2. 使用@Reference来注册消费者时,调用服务时出现空指针异常;
3. 使用com.alibaba.dubbo.config.annotation.Service导致事务失效;
第一个问题解决方案
在spring的xml文件中配置如下即可,
<!-- 提供方应用信息,用于计算依赖关系 -->
<dubbo:applicationname="${zookeeper.name}"/>
<!-- 使用zookeeper注册中心暴露服务地址 -->
<dubbo:registryprotocol="zookeeper"address="${zookeeper.address}"/>
<!-- 用dubbo协议在20880端口暴露服务
-->
<dubbo:protocolname="dubbo"port="${zookeeper.port}"/>
<!-- 声明需要暴露的服务接口 <dubbo:serviceinterface="com.cxb.uc.test.ITestService2"
ref="testService2Impl" />-->
<!-- 使用注解方式暴露接口 -->
<dubbo:annotationpackage="com.cxb.uc"/>
配置文件大同小异,都是这样,基本没什么问题,但是在使用@Service注解时出现了一个奇怪的问题,使用DubboAdmin时,全部都是代理对象的名字,一堆proxy。最后在如下解决:
@Service(interfaceName="com.test.ITestService")
直接使用iterfaceName命名服务名。
到此第一个问题告一段落。
第一个问题解决好后,便觉的没什么其他问题了。
项目发布很正常,一切都和预=预期一样正常,可是到测试接口的时候,遇到第二个问题,一直会出现空指针异常:
网上解决方法很多,尝试了好多,最终在配置文件实现,就是在spring的核心xml文件中配置一遍dubbo的相关配置,同时在springMVC的xml的最前再边配置一遍,原因就是,spring的注解扫描会导致dubbo失效,(具体原因没有细究,这里留下疑问)。配置如下:
Context的xml配置
<dubbo:applicationname="${zookeeper.name}"/>
<!-- 使用zookeeper注册中心暴露服务地址 -->
<dubbo:registry
89dd
protocol="zookeeper"address="${zookeeper.address}"/>
<!-- 要引用的服务 -->
<dubbo:annotation/>
<!-- 启用spring mvc注解 -->
<context:annotation-config/>
springMVC配置文件中将上述也放到最前边就可以解决。
第三个问题是在添加事务管理的时候发现的,解决方案,在该博客发现
http://jhaij.iteye.com/blog/2171723
当加入事务后,spring bean 事务代理, dubbo的 AnnotationBean 扫描 类执行下面的代码的时候就获取不到对应的注解,也就发布不了服务:
Java代码
Service service =bean.getClass().getAnnotation(Service.class);
if (service != null) {
因为被cglib或者java proxy 代理的类获取不到该dubbo的service注解.
我按照方法,直接去maven库中,将加上java.lang.annotation.Inherited 注解的Service.class替换进去。实际上我在查看github上的最新dubbo源码时,这个注解已经添加了,不知道为啥不发不到Maven库中。
以上就是这次简陋的不谨慎的总结。
相关文章推荐
- android客户端通过Get方式提交参数给服务器,使用URL和HttpURLConnection实现,以及乱码问题解决
- 使用SpringMVC注解时浏览器开发者工具中出现404问题以及解决方法
- 面向过程就是分析出解决问题所需要的步骤,然后用函数把这些步骤一步一步实现,使用的时候一个一个依次调用就可以了;面向对象是把构成问题事务分解成各个对象,建立对象的目的不是为了完成一个步骤,而是为了描叙某个事物在整个解决问题的步骤中的行为(转)
- jquery1.8版本使用ajax实现微信调用出现的问题分析及解决办法
- android客户端通过Get方式提交参数给服务器,使用URL和HttpURLConnection实现,以及乱码问题解决
- 细讲android获取流量使用情况,以及解决调用流量接口不准问题(非TrafficStats,而是NetworkStatsHistory)
- 使用接口的方式调用远程服务 ------ 利用动态调用服务,实现.net下类似Dubbo的玩法。
- spring注解实现业务层事务管理,当业务层自调用时,事务失效问题解决
- spring注解实现业务层事务管理,当业务层自调用时,事务失效问题解决
- 解决vue中使用Axios调用接口时出现的ie数据处理问题
- 在dubbo调用实现类的方法时出现空指针的解决问题
- (9) 使用Spring的注解方式实现AOP入门 以及 细节
- 被事务代理的spring service 不能使用注解方式发布dubbo服务
- 使用gyp构建项目,使用ninja更快的编译,以及使用出现和解决的问题记录
- WCF Rest:不使用UriTemplate使用post方式传参解决HTTP400问题以及参数映射问题
- 11.Cocos2dx2.2下使用JNI技术调用jar包里面的一些方法遇到的一些问题及解决方式。
- 就自己使用ASP.NET写的小系统中出现的问题总结与解决方式
- 使用solr4.9部署到tomcat上出现Context [/solr] startup failed due to previous errors问题以及解决办法
- (10) 使用Spring的注解方式实现AOP入门 以及 细节
- 使用SSM的时候添加自定义的监听器(实现已知的那几个接口)出现报错的问题 推荐