上一篇介绍了单机版zookeeper安装,这种情况一般用于开发测试。如果是生产环境建议用分布式集群部署,防止单点故障,增加zookeeper服务的高可用。

【环境介绍】

      三台机器:192.168.126.160,192.168.126.161,192.168.126.162

      操作系统:centos linux

以上就是本次集群的机器情况。下面进行安装和配置:

一、安装和配置

1)解压文件(先在一台机器上操作

tar -zxvf zookeeper-3.4..tar.gz

2)重命名配置文件zoo_sample.cfg并修改其内容如下:

mv zoo_sample.cfg zoo.cfg
vim zoo.cn

内容为:

tickTime=2000
dataDir=/home/mysql/zookeeper-3.4.6/data
clientPort=2181
initLimit=5
syncLimit=2
server.1=192.168.126.160:2888:3888
server.2=192.168.126.161:2888:3888
server.3=192.168.126.162:2888:3888

tickTime:该参数用来定义心跳的间隔时间,zookeeper的客户端和服务端之间也有和web开发里类似的session的概念,而zookeeper里最小的session过期时间就是tickTime的两倍。单位是毫秒

dataDir:  存放内存数据库的快照,用户恢复数据,如果不指定logdatadir,那么默认log也会存在这里。

clientPort:供客户端程序连接的端口,如果在单机部署多台server,那么端口需要不同。

server.x:用于集群中发现彼此,这里的1,2,3需要跟data/myid里数字对应,后面会有说明。2888表示集群中互联的端口,3888用于选主的端口。

initLimit:参数设定了允许所有跟随者与领导者进行连接并同步的时间,如果在设定的时间段内,半数以上的跟随者未能完成同步,领导者便会宣布放弃领导地位,进行另一次的领导选举。如果zk集群环境数量确实很大,同步数据的时间会变长,因此这种情况下可以适当调大该参数。默认为10
syncLimit:参数设定了允许一个跟随者与一个领导者进行同步的时间,如果在设定的时间段内,跟随者未完成同步,它将会被集群丢弃。所有关联到这个跟随者的客户端将连接到另外一个跟随着。

然后,把修改好的zookeeper安装文件传输到其他两台机器上:

 scp -r zookeeper-3.4. 192.168.126.161:/home/

3)设置myid

在我们配置的dataDir指定的目录下面,创建一个myid文件,里面内容为一个数字,用来标识当前主机,conf/zoo.cfg文件中配置的server.X中X为什么数字,则myid文件中就输入这个数字,例如:

192.168.126.160> cd /zookeeper-3.4./data && touch myid && echo "" >myid
192.168.126.161> cd /zookeeper-3.4./data && touch myid && echo "" >myid
192.168.126.162> cd /zookeeper-3.4./data && touch myid && echo "" >myid

到这里,整个集群就配置好了。

二、启动

192.168.126.160> cd /zookeeper-3.4./bin
192.168.126.160 bin> ./zkServer.sh start
JMX enabled by default
Using config: /home/mysql/zookeeper-3.4./bin/../conf/zoo.cfg
Starting zookeeper ... STARTED 192.168.126.161> cd /zookeeper-3.4./bin
192.168.126.161 bin> ./zkServer.sh start
JMX enabled by default
Using config: /home/mysql/zookeeper-3.4./bin/../conf/zoo.cfg
Starting zookeeper ... STARTED 192.168.126.162> cd /zookeeper-3.4./bin
192.168.126.162 bin> ./zkServer.sh start
JMX enabled by default
Using config: /home/mysql/zookeeper-3.4./bin/../conf/zoo.cfg
Starting zookeeper ... STARTED

安装正确,以上三台都启动了,组成了一个zookeeper集群,即使其中一台down机了,其他两台还可以继续提供服务。

三、命令

1、查看集群机器状态:

192.168.126.160>  ./zkServer.sh status
JMX enabled by default
Using config: /home/mysql/zookeeper-3.4./bin/../conf/zoo.cfg
Mode: follower 192.168.126.161> ./zkServer.sh status
JMX enabled by default
Using config: /home/mysql/zookeeper-3.4./bin/../conf/zoo.cfg
Mode: leader 192.168.126.162> ./zkServer.sh status
JMX enabled by default
Using config: /home/mysql/zookeeper-3.4./bin/../conf/zoo.cfg
Mode: follower

126.161机器是leader,其他都是小弟角色。

2、通过客户端脚本连接到集群:

现在整个集群对外是一个整体,连接到任意一台机器上看到的视图都是一样的。

192.168.126.162> ./zkCli.sh -server 192.168.126.160:
Connecting to 192.168.126.160:
-- ::, [myid:] - INFO [main:Environment@] - Client environment:zookeeper.version=3.4.-, built on // : GMT
-- ::, [myid:] - INFO [main:Environment@] - Client environment:host.name=darren.org
-- ::, [myid:] - INFO [main:Environment@] - Client environment:java.version=1.7.0_67
-- ::, [myid:] - INFO [main:Environment@] - Client environment:java.vendor=Oracle Corporation
-- ::, [myid:] - INFO [main:Environment@] - Client environment:java.home=/usr/java/jdk1..0_67-cloudera/jre
-- ::, [myid:] - INFO [main:Environment@] - Client environment:java.class.path=/home/mysql/zookeeper-3.4./bin/../build/classes:/home/mysql/zookeeper-3.4./bin/../build/lib/*.jar:/home/mysql/zookeeper-3.4.6/bin/../lib/slf4j-log4j12-1.6.1.jar:/home/mysql/zookeeper-3.4.6/bin/../lib/slf4j-api-1.6.1.jar:/home/mysql/zookeeper-3.4.6/bin/../lib/netty-3.7.0.Final.jar:/home/mysql/zookeeper-3.4.6/bin/../lib/log4j-1.2.16.jar:/home/mysql/zookeeper-3.4.6/bin/../lib/jline-0.9.94.jar:/home/mysql/zookeeper-3.4.6/bin/../zookeeper-3.4.6.jar:/home/mysql/zookeeper-3.4.6/bin/../src/java/lib/*.jar:/home/mysql/zookeeper-3.4.6/bin/../conf:.:/usr/java/jdk1.7.0_67-cloudera/lib/dt.jar:/usr/java/jdk1.7.0_67-cloudera/lib/tools.jar:/usr/java/jdk1.7.0_67-cloudera/jre/lib/rt.jar
2016-11-25 16:40:47,040 [myid:] - INFO [main:Environment@100] - Client environment:java.library.path=/usr/java/packages/lib/amd64:/usr/lib64:/lib64:/lib:/usr/lib
2016-11-25 16:40:47,040 [myid:] - INFO [main:Environment@100] - Client environment:java.io.tmpdir=/tmp
2016-11-25 16:40:47,040 [myid:] - INFO [main:Environment@100] - Client environment:java.compiler=<NA>
2016-11-25 16:40:47,040 [myid:] - INFO [main:Environment@100] - Client environment:os.name=Linux
2016-11-25 16:40:47,040 [myid:] - INFO [main:Environment@100] - Client environment:os.arch=amd64
2016-11-25 16:40:47,040 [myid:] - INFO [main:Environment@100] - Client environment:os.version=2.6.32-504.23.4.el6.x86_64
2016-11-25 16:40:47,040 [myid:] - INFO [main:Environment@100] - Client environment:user.name=root
2016-11-25 16:40:47,040 [myid:] - INFO [main:Environment@100] - Client environment:user.home=/root
2016-11-25 16:40:47,040 [myid:] - INFO [main:Environment@100] - Client environment:user.dir=/home/mysql/zookeeper-3.4.6/bin
2016-11-25 16:40:47,041 [myid:] - INFO [main:ZooKeeper@438] - Initiating client connection, connectString=192.168.126.160:2181 sessionTimeout=30000 watcher=org.apache.zookeeper.ZooKeeperMain$MyWatcher@71fdf17c
Welcome to ZooKeeper!
2016-11-25 16:40:47,073 [myid:] - INFO [main-SendThread(192.168.126.160:2181):ClientCnxn$SendThread@975] - Opening socket connection to server 192.168.126.160/192.168.126.160:2181. Will not attempt to authenticate using SASL (unknown error)
JLine support is enabled
2016-11-25 16:40:47,076 [myid:] - INFO [main-SendThread(192.168.126.160:2181):ClientCnxn$SendThread@852] - Socket connection established to 192.168.126.160/192.168
.126.160:2181, initiating session [zk: 192.168.126.160:2181(CONNECTING) 0] 2016-11-25 16:40:47,100 [myid:] - INFO [main-SendThread(192.168.126.160:2181):ClientCnxn$SendThread@1235] - Session establishment complete on server 192.168.126.160/192.168.126.160:2181, sessionid = 0x1589a9a25170000, negotiated timeout = 30000 WATCHER:: WatchedEvent state:SyncConnected type:None path:null [zk: 192.168.126.160:2181(CONNECTED) 0] 

查看数据:

[zk: 192.168.126.160:(CONNECTED) ] ls /
[zookeeper]

用ls /命令查看目录情况,发现只有一个zookeeper目录。

我们到安装目录的/data文件夹下看看都有什么文件?

-rw-r--r--  root root         Nov  : acceptedEpoch
-rw-r--r-- root root Nov : currentEpoch
-rw-r--r-- root root Nov : log.
-rw-r--r-- root root Nov : snapshot.

【解释】:

snapshot.0:就是我们存放数据在内存中的快照,zookeeper服务刚启动时需要用它来恢复数据
log.100000001:日志文件,默认存放在数据目录中。

到此为止,整个zookeeper集群环境的搭建配置就完成了,挺简单的吧。

【参考文献】:

zookeeper学习与实战(二)集群部署的更多相关文章

  1. ZooKeeper学习笔记一:集群搭建

    作者:Grey 原文地址:ZooKeeper学习笔记一:集群搭建 说明 单机版的zk安装和运行参考:https://zookeeper.apache.org/doc/r3.6.3/zookeeperS ...

  2. Zeebe服务学习3-Raft算法与集群部署

    1.背景Zeebe集群里面保证分布式一致性问题,是通过Raft实现的,其实这个算法用途比较广泛,比如Consul网关,也是通过Raft算法来实现分布式一致性的. 首先简单介绍一下Raft: 在学术界, ...

  3. kubernetes云平台管理实战: 集群部署(一)

    一.环境规划 1.架构拓扑图 2.主机规划 3.软件版本 [root@k8s-master ~]# cat /etc/redhat-release CentOS Linux release 7.4.1 ...

  4. 004.etcd集群部署-动态发现

    一 etcd发现简介 1.1 需求背景 在实际环境中,集群成员的ip可能不会提前知道.如使用dhcp自动获取的情况,在这些情况下,使用自动发现来引导etcdetcd集群,而不是指定静态配置,这个过程被 ...

  5. 003.etcd集群部署-静态发现

    一 etcd集群概述 1.1 概述 静态启动etcd集群要求每个成员都知道集群中的另一个成员.Etcd运行在集群的每个coreos节点上,可以保证coreos集群的稳定,可靠的运行.当集群网络出现动荡 ...

  6. Redis cluster 集群部署和配置

    目录 一.集群简介 cluster介绍 cluster原理 cluster特点 应用场景 二.集群部署 环境介绍 节点部署 启动集群 三.集群测试 一.集群简介 cluster介绍 redis clu ...

  7. Dubbo+zookeeper构建高可用分布式集群(二)-集群部署

    在Dubbo+zookeeper构建高可用分布式集群(一)-单机部署中我们讲了如何单机部署.但没有将如何配置微服务.下面分别介绍单机与集群微服务如何配置注册中心. Zookeeper单机配置:方式一. ...

  8. kafka学习总结之集群部署和zookeeper

    1.  集群部署 kafka集群的瓶颈主要在网络和磁盘上:kafka依赖于zookeeper,zookeeper集群的节点采用奇数个,3个节点允许一个节点失败,5个节点允许2个节点失败. 图 1 ka ...

  9. rocketmq学习(二) rocketmq集群部署与图形化控制台安装

    1.rocketmq图形化控制台安装 虽然rocketmq为用户提供了使用命令行管理主题.消费组以及broker配置的功能,但对于不够熟练的非运维人员来说,命令行的管理界面还是较难使用的.为此,我们可 ...

随机推荐

  1. MySQL 字符编码总结

    今天操作服务器数据库时遇到了Mysql中文字符乱码的问题,主要原因是因为安装的时候没有设置好字符集. 很是郁闷,因为库里有很多重要数据,所以重装是不可能了,于是决定找找在不重装且不改代码的前提下,能搞 ...

  2. Spark中经常使用工具类Utils的简明介绍

    <深入理解Spark:核心思想与源代码分析>一书前言的内容请看链接<深入理解SPARK:核心思想与源代码分析>一书正式出版上市 <深入理解Spark:核心思想与源代码分析 ...

  3. Atitit.跨平台预定义函数 魔术方法 魔术函数 钩子函数 api兼容性草案 v2 q216  java c# php js.docx

    Atitit.跨平台预定义函数 魔术方法 魔术函数 钩子函数 api兼容性草案 v2 q216  java c# php js.docx 1.1. 预定义函数 魔术方法 魔术函数是什么1 1.2. & ...

  4. ORACLE 12C R2 RAC 安装配置指南

    >> from zhuhaiqing.info ASM磁盘空间最低要求 求12C R2相比前一版本,OCR的磁盘占用需求有了明显增长.为了方便操作,设置如下:External: 1个卷x4 ...

  5. java编写socket使用bufferedReader.readLine()问题研究

    不写java代码好久,临时写个socket通讯竟然失败,郁闷之下仔细研究了下. 客户端使用BufferedReader来读取数据,在while中调用BufferedReader.readLine()函 ...

  6. route 命令

    Linux系统的route命令用于显示和操作IP路由表(show / manipulate the IP routing table).要实现两个不同的子网之间的通信,需要一台连接两个网络的路由器,或 ...

  7. 自己定义popupwindow二三事

    效果图: 代码: public class ViewActivity extends Activity implements View.OnClickListener { PopupWindow po ...

  8. Python 类方法、实例方法、静态方法

    实例方法:类中第一个参数为self的方法. 类方法:类中第一个参数为类,约定写为cls,并被@classmethod修饰的方法. 静态方法:类中被@staticmethod修饰的方法. 类变量:定义在 ...

  9. Centos date 设置自定义时间

    [1]手动修改 (1)设置日期 # date -s 20190315 (2)设置时间 # date -s 15:23:34 (3)设置日期和时间 # date -s "20190315 15 ...

  10. git使用命令行方式提交代码到github或gitlab上

    (1)使用命令行(Git Bash)在gitlab上新建项目的流程   //进入项目目录下: C:\Users\wuwy>cd D:\workspace\eclipse\H5Patient\// ...