Zookeeper分布式过程协同技术 -  部署及设置

Zookeeper支持单机模式、伪集群模式、集群模式三种部署方式。演示部署环境为CentOS、jdk版本为1.8、Zookeeper版本为3.4.9。

单机模式

单机模式适合入门学习使用,只需要一台机器就可以轻松搭建Zookeeper服务用于学习和测试。

1. 进入官网下载Zookeeper的JAR包,下载地址:https://zookeeper.apache.org/releases.html

2. 解压压缩包,命令:tar -zxvf zookeeper-3.4.9.tar.gz,解压后目录格式如下。

3. 进入conf目录,复制zoo_sample.cfg文件命名为zoo.cfg。这里可以直接使用默认的参数,也可以根据自己的需要修改。

命令:cp zoo_sample.cfg zoo.cfg

主要配置参数说明

  • clientPort

客户端连接的服务器所监听的TCP端口,默认情况下,服务器会监听所有的网络连接的这个端口,除非设置了clientPortAddress参数。客户端口可以设置为任何值,不同的服务器可以设置不同的端口,默认端口号为2181。

  • tickTime

tickTime的时长单位为毫秒,Zookeeper集群中使用的超时时间单位通过tickTime指定。tickTime设置了超时时间的下限值,因为最小的超时时间为一个tick时间,客户端最小会话超时时间为2个tick时间。

tickTime的默认值是3000毫秒,更低的tickTime值可以更快地发现超时问题,但也导致更高的网络流量和更高的CPU使用率。

  • dataDir

dataDir用于配置内存数据库保存的模糊快照目录,如果某个服务器为集群中的一台,id文件也保存在该目录下。

  • dataLogDir

用于配置事务日志的保存目录。服务端在确认一个事务前必须将数据同步到存储中,如果写入磁盘过于忙碌会影响到写入的吞吐能力。因此,比较好的方案是使用专用的日志存储设备,将dataLogDir目录配置指向该设备。

  • maxClientCnxns

允许每个IP地址发起socket连接的最大数量。Zookeeper通过流量控制和限制值来避免过载情况的发生。当某个IP地址的客户端建立的连接数大于此值时,服务器会拒绝该IP地址新的连接。

  • initLimit

对于追随者最初连接到群首时的超时时间,单位为tick(tickTime)值的倍数。

当某个追随者最初与群首建立连接时,它们之间会传输相当多的数据,尤其是追随者落后整体很多时。配置initLimit参数值取决于群首与追随者之间的网络传输速度以及传输数据量的大小。

但是如果设置值过高,在首次连接到故障的服务器就会消耗更多的时间,同时还会消耗更多的恢复时间。因此在实际部署时,最好进行集群间的网络基准测试来测试出你所期望的时间。

  • syncLimit

对于追随者与群首进行sync操作时的超时值,单位为tick(tickTime)值的倍数。

追随者总是会稍落后于群首,如果群首与追随者无法进行sync操作,而且超过了syncLimit的tick时间,就会放弃该追随者。

  • leaderServes

配置值为“yes”或“no”标志,指示群首服务器是否为客户端提供服务。担任群首的服务器需要做很多工作,它需要与所有的追随者进行通信并会执行所有的变更操作,这意味着群首的负载会比追随者高很多,如果群首过载,整个系统都有可能受到影响。

4. 进入bin目录,可以看到很多sh脚本文件,通过zkServer.sh来启动zookeeper。

操作命令:

启动命令:.zkServer.sh start

停止命令:.zkServer.sh stop

重启命令:.zkServer.sh restart

状态查看命令:.zkServer.sh status

启动zookeeper服务后,通过status命令可以看到当前服务状态、使用的配置文件、运行模式。

这样Zookeeper的单机部署模式就已经初步完成了。如果需要修改JVM配置,可以修改zkServver.sh文件中的配置,在如下位置加入你需要的参数。

伪集群部署

伪集群部署指在一台机器上部署多个Zookeeper服务。

1. 首先将之前配置好的Zookeeper服务目录另外复制两份,命名为zookeeper-2和zookeeper-3。

2. 然后分别修改三份的zoo.cfg配置项,添加配置 server.x=[hostname]:n:n[:observer],示例如下。

server.1=localhost:2887:3887

server.2=localhost:2888:3888

server.3=localhost:2889:3889

Zookeeper服务器需要知道它们如何通信,配置文件中该形式的配置项就指定了服务器x的配置信息,其实x为服务器的ID值(一个整数)。当一个服务器启动后,就会读取data目录下myid文件中的值,之后服务器就会使用这个值作为查找server.x项,通过该项中的数据配置服务器自己。如果需要连接到另外一个服务器y,就会使用server.y项配置信息来与这个服务器进行通信。

hostname为服务器在网络中的名称(ip或者主机名),同时后面跟着两个端口号,第一个端口号用于事务的发送,第二个端口号用于群首选举。如果最后一个字段标记了observer属性(选填),服务器就会进入观察者模式。

三份配置文件的myid和两个配置端口号以及clientPort不可以重复,因为是在一台机器上部署,生产环境集群部署时可以忽略。最终的配置清单如下:

3. 分别添加myid文件,在data目录下添加myid文件。

echo '1' > data/myid

4. 分别启动三个Zookeeper服务,启动成功后通过status命令可以查看服务的状态。可以看到目前集群里有一台leader和两台follower。

集群部署

生产环境的集群部署步骤和伪集群部署并无太多差异,同样是修改zoo.cfg配置文件并且添加Zookeeper集群信息,集群部署时,客户端端口号、事务端口号、选举端口号都可以保持一致。另外集群部署时需要充分考虑集群机器间的网络情况来制定合理的超时时间设置。

最新文章

  1. shell九九乘法表
  2. The Non-Inverting Amplifier Output Resistance by Adrian S. Nastase [ Copied ]
  3. Appium移动自动化测试(二)--安装Android开发环境
  4. 阿里公共DNS 正式发布了
  5. sudo: unable to resolve host XXX 解决方法
  6. MVC区域 vs2013 mvc 搭建基架项
  7. MVC5个人用户账户身份验证集成google和facebook的OAuth2登陆
  8. 如何更新 OpenStack 组件?- 每天5分钟玩转 OpenStack(161)
  9. Vi快捷操作 vim配置【shell文件格式从windows转换为linux】
  10. 注解@PostConstruct与@PreDestroy 特性说明
  11. vue.js数据可以在页面上渲染成功却总是警告提示某个字段“undefined”未定义
  12. leetcode-查找和替换模式
  13. 爬虫-requests
  14. RabbitMQ消费者抛异常日志持续打印的问题
  15. web前端监控的三个方面探讨
  16. vs2017下发现解决python运行出现‘No module named "XXX""的解决办法
  17. 微信出现BUG,发送“ 两位数字+15个句号 ”,双方系统会卡崩……
  18. C#中 == 与 Equals的简单理解
  19. Spring Shell打Jar包时需要注意的地方
  20. Myeclipse2016安装Aptana

热门文章

  1. Rocket - util - ReduceOthers
  2. Mysql查询语句,select,inner/left/right join on,group by.....[例题及答案]
  3. JavaScript (五) js的基本语法 - - - 面向对象、工程模式、内置对象、JSON
  4. Java实现 LeetCode 701 二叉搜索树中的插入操作(遍历树)
  5. Java实现 蓝桥杯VIP 算法训练 确定元音字母位置
  6. Java实现 洛谷 P1280 尼克的任务
  7. java实现土地测量
  8. Java实现第八届蓝桥杯最大公共子串
  9. Java实现第九届蓝桥杯星期一
  10. snowflake原理解析