Dubbo

1、系统间通信

无论是soa(面向服务架构)还是分布式架构,每个独立的业务之间都需要系统间通信。比如实现商品列表查询需要两个系统之间通信。系统之间的远程通信有几种方式呢?
1.1、Webservice:效率不高,基于soap协议。不推荐使用。
1.2、restful:基于http+json。很多项目中使用,但是如果服务太多的话,服务间调用混乱,需要治疗。
1.3、dubbo:使用rpc协议进行远程调用,直接使用socket通信。传输效率高,并且可以统计系统之间的调用关系、调用次数。

2、什么是dubbo

文档 http://dubbo.io/User+Guide-zh.htm
dubbo就是资源调度和治理中心的管理工具。
dubbo采用全spring配置方式,透明化接入应用,对应用没有任何api侵入,只需要spring加载dubbo的配置即可,dubbo基于spring的schema进行扩展。
dubbo扩展了spring schema定义,两条定义如下:

xmlns:dubbo="http://code.alibabatech.com/schema/dubbo" 
http://code.alibabatech.com/schema/dubbo http://code.alibabatech.com/schema/dubbo/dubbo.xsd

dubbo schema定义了如下对象:

  • ApplicationConfig
  • ModuleConfig
  • RegistryConfig
  • MonitorConfig
  • ProviderConfig
  • ConsumerConfig
  • ProtocolConfig
  • ServiceBean
  • ReferenceBean
  • AnnotationBean

在spring xml文件中按照下面的方式注入dubbo schema中定义的对象:

<dubbo:application name="hello-world-app"  />
<dubbo:registry address="multicast://224.5.6.7:1234" />
<dubbo:protocol name="dubbo" port="20880" />
<dubbo:service interface="com.alibaba.dubbo.demo.DemoService" ref="demoServiceLocal" />
<dubbo:reference id="demoServiceRemote" interface="com.alibaba.dubbo.demo.DemoService" />
<dubbo:annotation package="com.alibaba.dubbo.config.spring.annotation.consumer" />

3、dubbo的架构

  • Provider: 暴露服务的服务提供方
  • Consumer: 调用远程服务的服务消费方
  • Registry: 服务注册与发现的注册中心(zookeeper)
  • Monitor: 统计服务的调用次数和调用时间
  • Container: 服务运行容器

4、dubbo的使用

4.1、安装注册中心zookeeper
注册中心负责服务地址的注册和查找,相当于目录服务,服务提供者与消费者只在注册中心启动与注册中心交互,注册中心不转发请求。zookeeper是Apache Hadoop的一个子项目,是一个树形的目录服务,支持变更推送,所以推荐使用。安装步骤如下:
1、安装jdk
2、解压缩zookeeper包
3、将conf文件夹下zoo_sample.cfg复制一份改名为zoo.cfg
4、修改dataDir属性,指定一个真实路径
5、启动zookeeper:bin/zkServer.sh start
关闭zookeeper:bin/zkServer.sh stop
查看zookeeper状态:bin/zkServer.sh status

4.2、spring配置及服务发布与引用

  • 定义服务接口: (该接口需单独打包,在服务提供方和消费方共享)
  • 在服务提供方实现接口:(对服务消费方隐藏实现)
  • 用Spring配置声明暴露服务
  • 加载提供方Spring配置
  • 通过Spring配置引用远程服务
  • 加载消费方Spring配置,并调用远程服务(也可以使用IoC注入)

服务提供方暴露服务:
放在service工程中,例如:taotao-manager-service,taotao-content-service

  • 需要注册地址。
  • 需要暴露服务端口。端口决定不同的服务,即每个服务的端口是不一样的。
  • 需要声明服务接口,关键字是dubbo:service ,“interface”是interface工程中定义的服务接口,“ref”是service工程中服务提供方实现的接口。
<!-- 发布dubbo服务 -->
    <!-- 提供方应用信息,用于计算依赖关系 -->
    <dubbo:application name="taotao-manager" />
    <!-- 注册中心的地址 -->
    <dubbo:registry protocol="zookeeper" address="192.168.25.167:2181" />
    <!-- 用dubbo协议在20880端口暴露服务 -->
    <dubbo:protocol name="dubbo" port="20880" />
    <!-- 声明需要暴露的服务接口 -->
    <dubbo:service interface="com.taotao.service.ItemService" ref="itemServiceImpl" timeout="300000"/>
    <dubbo:service interface="com.taotao.service.ItemCatService" ref="itemCatServiceImpl" timeout="300000"/>

加载提供方spring配置

ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(new String[] {"http://10.20.160.198/wiki/display/dubbo/provider.xml"});

context.start();

服务消费方引用服务:
放在web工程中,例如taotao-manager-web,taotao-item-web

  • 需要注册地址。
  • 需要引用服务接口,关键字是dubbo:reference,“interface”是interface工程中定义的服务接口,“id”一般为首字母小写的对应接口类名称。
<!-- 引用dubbo服务 -->
    <dubbo:application name="taotao-manager-web"/>
    <dubbo:registry protocol="zookeeper" address="192.168.25.167:2181"/>    
    <dubbo:reference interface="com.taotao.service.ItemService" id="itemService" />
    <dubbo:reference interface="com.taotao.service.ItemCatService" id="itemCatService" />
    <dubbo:reference interface="com.taotao.content.service.ContentCategoryService" id="contentCategoryService" />
    <dubbo:reference interface="com.taotao.content.service.ContentService" id="contentService" />
    <dubbo:reference interface="com.taotao.search.service.SearchItemService" id="searchItemService" />

加载消费方spring配置

ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(
                new String[] { "http://10.20.160.198/wiki/display/dubbo/consumer.xml" });
context.start();
DemoService demoService = (DemoService) context.getBean("demoService"); // 获取远程服务代理
String hello = demoService.sayHello("world"); // 执行远程方法
System.out.println(hello); // 显示调用结果
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,189评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,577评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,857评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,703评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,705评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,620评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,995评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,656评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,898评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,639评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,720评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,395评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,982评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,953评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,195评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,907评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,472评论 2 342

推荐阅读更多精彩内容