Dubbo项目的简单搭建过程

image.png

由于这段时间一直在微服务进行实践,过程中尝试用dubbo作为rpc框架搭建了一个简单的项目,下面给大家简单说明下这个项目。

项目在github上的地址:https://github.com/shangjing105/dubbo

dubbo介绍&&项目简介

  1. Dubbo是一个分布式服务框架,以及SOA治理方案。其功能主要包括:高性能NIO通讯及多协议集成,服务动态寻址与路由,软负载均衡与容错,依赖分析与降级等。

  2. Dubbo官网:http://dubbo.apache.org/,官网上有关于dubbo的一些项目和jar包资源下载。

  3. 项目使用的是springboot架构,可以进行快速开发。

  4. 项目分为3个模块,分别为服务提供者,消费者,API接口层。

  5. 使用zookeeper作为注册中心

provide服务提供者

provide服务提供者,对外提供服务接口。这个项目里提供者即使提供者也是消费者。

  1. 加入Jar包
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>dubbo</artifactId>
            <version>2.6.0</version>
        </dependency>
        <dependency>
            <groupId>org.apache.zookeeper</groupId>
            <artifactId>zookeeper</artifactId>
            <version>3.4.6</version>
        </dependency>
        
  1. 配置服务提供者
     <!-- 提供方应用信息,用于计算依赖关系 -->
     <dubbo:application name="${dubbo.application.name}" />
     <!-- 注册中心暴露服务地址 -->
     <dubbo:registry protocol="${dubbo.registry.protocol}" address="${dubbo.registry.address}" />
     <!-- 暴露服务方式和端口 -->
     <dubbo:protocol name="${dubbo.protocol.name}" port="${dubbo.protocol.port}" />
     <!-- 服务提供者 -->
     <dubbo:service interface="com.hejia.api.service.UserService" ref="userServiceImpl" version="1.0.0" timeout="600" />
     <!-- 服务消费者 -->
     <dubbo:reference interface="com.hejia.api.service.UserService" id="userService" version="1.0.0" check="false"/>

这里需要注意的是在注入提供者和消费者的时候要注意ref与id要对应不同的实例化对象。

  1. 配置
#应用名称
dubbo.application.name=pisces-provider
#注册中心类型
dubbo.registry.protocol=zookeeper
#注册中心地址
dubbo.registry.address=127.0.0.1:2181
#暴露服务方式
dubbo.protocol.name=dubbo
#暴露服务端口
dubbo.protocol.port=18020

配置完这些后,其他地方的代码都正常开发流程一样,对代码的侵入性很小,只需加入少量的配置文件,即可实现功能分布式rpc调用。

相关代码可以看我项目里的实现。

consumer服务消费者

provide服务消费者,消费提供者提供的接口。

这里没有过多代码,就是注入一个service,然后调用方法就可以了。配置和上面的类似。

  1. 服务配置
    <!-- 提供方应用信息,用于计算依赖关系 -->
    <dubbo:application name="${dubbo.application.name}" />
    <!-- 注册中心暴露服务地址 -->
    <dubbo:registry protocol="${dubbo.registry.protocol}" address="${dubbo.registry.address}" />

    <dubbo:reference interface="com.hejia.api.service.UserService" id="userService" version="1.0.0" check="false"/>
  1. 参数配置
#应用名称
dubbo.application.name=pisces-consumer
#注册中心类型
dubbo.registry.protocol=zookeeper
#注册中心地址
dubbo.registry.address=127.0.0.1:2181

API接口层

api接口层,需要将API打包成jar包,在下面两个工程里定义。内部的dto,exception包是接口对外的数据模型和异常信息。

将接口层提取出来作为统一的接口层,方面在各个服务里接口不同服务。

至于dto层和exception层可以根据需求看看在各自服务里是否需要使用。

注册管理中心的安装

  1. 安装Zookeeper

下载Zookeeper安装包,然后安装启动即可。默认的Zookeeper地址是:127.0.0.1 2181

  1. 安装管理控制台

下载dubbo-opsx项目,然后编译放到tomcat下启动即可。可以在项目里编辑简单的dubbo配置

vi webapps/ROOT/WEB-INF/dubbo.properties

 dubbo.registry.address=zookeeper://127.0.0.1:2181
#配置dubbo的默认账号密码
 dubbo.admin.root.password=root
 dubbo.admin.guest.password=guest

结束

上面就是dubbo的简单使用,如果有不清楚的可以去dubbo官网或给我留言,我会尽快回复你。

有兴趣的可以关注我的博客,我会不时更新相关文章。

我的博客:http://www.shuihua.me/

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,377评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,390评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,967评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,344评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,441评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,492评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,497评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,274评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,732评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,008评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,184评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,837评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,520评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,156评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,407评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,056评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,074评论 2 352

推荐阅读更多精彩内容