Spring Boot如何集成dubbo服务

[size=large]
Spring Boot是什么?
Spring Boot提供了一个强大的一键式Spring的集成开发环境,能够单独进行一个Spring应用的开发,其中:

(1)集中式配置(application.properties)+注解,大大简化了开发流程
(2)内嵌的Tomcat和Jetty容器,可直接打成jar包启动,无需提供Java war包以及繁琐的Web配置
(3)提供了Spring各个插件的基于Maven的pom模板配置,开箱即用,便利无比。
(4)可以在任何你想自动化配置的地方,实现可能
(5)提供更多的企业级开发特性,如何系统监控,健康诊断,权限控制
(6) 无冗余代码生成和XML强制配置
(7)提供支持强大的Restfult风格的编码,非常简洁


最近项目中,由于要写一个服务,所以就用到了比较方便的Spring Boot项目,之前也用过,和这次不一样的是这次的项目里面要使用阿里的dubbo组件,作为服务化管理中心,原本的普通的spring项目集成dubbo是非常简单的,但由于用的Spring Boot,在网上搜了一下,还没有找到相关的资料的,所以就自己尝试了一下,发现并没有想象中的那么难,因为毕竟都是Spring自家的东西,没有理由不支持dubbo。


当然这里这个例子,我是服务使用方,会调用别人提供的dubbo服务,所以要通过xml声明dubbo的服务发布方 , Spring Boot其实是支持xml的bean初始化的,虽然不推荐使用,但是它还是有这个功能的,Spring Boot更推荐的使用方式是注解+集中式的properties文件配置,但由于必须要使用Spring Boot,所以不得不这样干了, 先看下dubbo的xml配置,该文件位于resource目录下:
[/size]


[img]http://dl2.iteye.com/upload/attachment/0111/0615/ec1bbf57-afc8-30fb-b0eb-785f74c72018.png[/img]
另外在resource目录下,还需要加入dubbo.properties文件

dubbo.application.name=xxxx
dubbo.application.owner=xxxx
dubbo.application.logger=slf4j
dubbo.registry.address=zookeeper://zk.xxxx.com:2181
dubbo.monitor.protocol=registry
dubbo.protocol.name=dubbo
dubbo.protocol.port=20887
dubbo.service.loadbalance=roundrobin
# dubbo \u8bbe\u8ba1\u7684\u65f6\u5019\u4e00\u53f0\u673a\u5668\u4e4b\u8fd0\u884c\u4e00\u4e2ajvm\uff0c\u73b0\u5728\u591a\u4e2a\u540c\u65f6\u4f7f\u7528\uff0c\u9700\u8981\u4fee\u6539\u914d\u7f6e\u9879
dubbo.registry.file=/ROOT/tmp/dubbo_cus/www_xxxxx_cn.properties


然后需要在maven的pom文件中,加入duboo的依赖:
           

com.alibaba
dubbo
2.4.1<


spring
org.springframework




OK,接下来需要在Spring Boot的主启动类加上,第一步的定义的duboo的xml文件,截图:
  
package com.anytrust.index.manager;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.ImportResource;

@ComponentScan//组件扫描
@Configuration//配置控制
@EnableAutoConfiguration//启用自动配置
@ImportResource({"classpath:dubboContext.xml"}) //加入spring的bean的xml文件
public class ApplicationMain {
public static void main(String[] args) throws Exception {
//启动Spring Boot项目的唯一入口
SpringApplication.run(ApplicationMain.class, args);

}

}


一个测试的服务的类如下:

[img]http://dl2.iteye.com/upload/attachment/0111/0617/3e127453-20b8-3a33-9f63-954147ee9053.png[/img]

[size=large]上面截图中,那个实例类,报错,不影响项目运行测试,所以可以忽略,最后,单元测试可以通过,后续会观察一下集成是否比较顺畅,因为Spring Boot是一个比较新的东西,虽然国外用的比较多,但国内用户还是比较少的,这样尝试,还是有点风险的,但测试一下也不错,如果可行,以后做项目也多了一种思路,还是挺好的。[/size]

[b][color=green][size=large]
最后欢迎大家扫码关注微信公众号:我是攻城师(woshigcs),我们一起学习,进步和交流!(woshigcs)
本公众号的内容是有关搜索和大数据技术和互联网等方面内容的分享,也是一个温馨的技术互动交流的小家园,有什么问题随时都可以留言,欢迎大家来访!
[/size][/color][/b]
[img]http://dl2.iteye.com/upload/attachment/0104/9948/3214000f-5633-3c17-a3d7-83ebda9aebff.jpg[/img]

你可能感兴趣的:(Spring Boot如何集成dubbo服务)