背景:
最近公司一个项目需要用到dubbo+zookeeper,所以整理一下最近学习dubbo和zookeeper的过程,想把完整的思路提供给初学者,仅供参考.
感谢这位大神的文章:
http://blog.csdn.net/guangyuj/article/details/78053957
ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务
Windows下安装
把下载的zookeeper的文件解压到指定目录
D:\machine\zookeeper-3.3.6>
修改conf下增加一个zoo.cfg
内容如下:
# The number of milliseconds of each tick 心跳间隔 毫秒每次
tickTime=2000
# The number of ticks that the initial
# synchronization phase can take
initLimit=10
# The number of ticks that can pass between
# sending a request and getting anacknowledgement
syncLimit=5
# the directory where the snapshot isstored. //镜像数据位置
dataDir=D:\\data\\zookeeper
#日志位置
dataLogDir=D:\\logs\\zookeeper
# the port at which the clients willconnect 客户端连接的端口
clientPort=2181
注:如果启动有报错提示cfg文件有错误,可以用zoo_sample.cfg内内容替代也是可以的
启动成功页面为:
1) 访问dubbo官网, https://github.com/alibaba/dubbo
2) 将压缩包解压到一个自定义位置
3) 在当前目录下打开命令窗口,使用命令mvn clean install -Dmaven.test.skip=true构建dubbo源码
4) 构建完成之后,找到上图中dubbo-admin下target文件夹中的war包,将其拷贝到本地的tomcat的webapps下
5) 测试搭建的dubbo+zookeeper是否成功,
先启动zookeeper,然后启动tomcat在浏览其中输入地址http://localhost:tomcat端口号/war的名字/ 回车,输入用户名和密码,用户名和密码均为root,这时候就会看到dubbo控制台,如下图.
随着互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行,亟需一个治理系统确保架构有条不紊的演进。
( # )
在大规模服务化之前,应用可能只是通过RMI或Hessian等工具,简单的暴露和引用远程服务,通过配置服务的URL地址进行调用,通过F5等硬件进行负载均衡。
(1) 当服务越来越多时,服务URL配置管理变得非常困难,F5硬件负载均衡器的单点压力也越来越大。
此时需要一个服务注册中心,动态的注册和发现服务,使服务的位置透明。
并通过在消费方获取服务提供方地址列表,实现软负载均衡和Failover,降低对F5硬件负载均衡器的依赖,也能减少部分成本。
(2) 当进一步发展,服务间依赖关系变得错踪复杂,甚至分不清哪个应用要在哪个应用之前启动,架构师都不能完整的描述应用的架构关系。
这时,需要自动画出应用间的依赖关系图,以帮助架构师理清理关系。
(3) 接着,服务的调用量越来越大,服务的容量问题就暴露出来,这个服务需要多少机器支撑?什么时候该加机器?
为了解决这些问题,第一步,要将服务现在每天的调用量,响应时间,都统计出来,作为容量规划的参考指标。
其次,要可以动态调整权重,在线上,将某台机器的权重一直加大,并在加大的过程中记录响应时间的变化,直到响应时间到达阀值,记录此时的访问量,再以此访问量乘以机器数反推总容量。
以上是Dubbo最基本的几个需求,更多服务治理问题参见:
节点角色说明:
调用关系说明:
1,新建三个maven项目
其中,第一个和第三个为服务提供者,第二个为服务消费者
2, 这三个项目需要放在三个tomcat中启动,启动顺序: 服务提供者先启动,服务消费者再启动
3, 第二个和第三个工程,都有一个启动主方法,运行完主方法后(主方法是为了模拟服务一直开着),在dubbo的监控中心就能看到相应的消费者和提供者信息了
完整的demo源码: http://download.csdn.net/download/gjm15652957971/10045396