Dubbo剖析-搭建一个简单的分布式系统(2)
一、前言
前面时间基于Spring的xml配置的方式搭建了一个简单的包含服务提供(Provider),服务注册中心(Registry),服务消费(Consumer)的分布式系统。本节我们不使用Spring配置方式,使用DUBBO提供的API来做。
二、服务注册中心
服务注册中心内容不变使用zookeeper实现服务注册中心。
- 首先你需要在 http://zookeeper.apache.org/releases.html 下载一个zk的包,并解压,本文作者使用的是zookeeper-3.4.11这个版本
- 然后修改zookeeper-3.4.11/conf文件夹里面的zoo.cfg文件里面的dataDir为一个存在的以data结尾的文
件 - 然后在zookeeper-3.4.11/bin 下运行sh zkServer.sh start-foreground 就会启动zk,会有下面输出
可知zk在端口2181进行监听。
至此服务注册中心搭建完毕
三、服务提供与消费
本demo使用maven聚合功能,demo目录如下
- 其中Consumer模块为服务消费者
- 其中Provider模块为服务提供者
- 其中SDK模块是一个二方包,用来存放服务提供者所有的接口,是为了代码复用使用。
3.1 SDK模块
里面就定义了一个接口,代码如下:
在该模块执行mvn clean install 命令会按照该模块的jar到本地仓库。
3.2 服务提供模块
在该模块引入SDK模块,其实是为了使用UserServiceBo这个接口。
然后UserServiceImpl实现代码如下:
测试类TestProvider代码如下:
运行上面代码,在控制台会输出如下:
说明该服务已经注册到了zk.
3.2 服务消费模块
首先引入SDK 二方包
测试类代码如下:
执行代码输出如下:
说明已经消费到了服务提供者的服务了。
四、总结
本节使用API的方式搭建了一个服务提供(Provider),服务注册中心(Registry),服务消费(Consumer)的分布式系统。在非Spring环境下,可以尝试使用这种方式。
原创文章,转载请注明: 转载自并发编程网 – ifeve.com本文链接地址: Dubbo剖析-搭建一个简单的分布式系统(2)
暂无评论