1. 介绍zookeeper
ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,是Google的Chubby一个开源的实现,是Hadoop和Hbase的重要组件。它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护、名字服务、分布式同步、组服务等。
ZooKeeper的目标就是封装好复杂易出错的关键服务,将简单易用的接口和性能高效、功能稳定的系统提供给用户。
ZooKeeper包含一个简单的原语集,[1] 提供Java和C的接口。
ZooKeeper代码版本中,提供了分布式独享锁、选举、队列的接口,代码在zookeeper-3.4.3\src\recipes。其中分布锁和队列有Java和C两个版本,选举只有Java版本。
2. 安装环境
1、Linux version 3.10.0-514.el7.x86_64
2、JDK 1.8
3. 安装步骤
- 下载zookeeper
Linux命令行直接下载:wget http://apache.fayea.com/zookeeper/zookeeper-3.4.13/zookeeper-3.4.13.tar.gz - 解压文件 tar -zxvf zookeeper-3.4.13.tar.gz
- 创建对应的文件夹
cd /usr/local/zookeeper
mkdir data
mkdir logs
- 在zookeeper-.3.4.13文件夹中的conf目录 复制zoo_sample.cfg配置文件
- cp zoo_sample.cfg 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 an acknowledgement
syncLimit=5
# the directory where the snapshot is stored.
# do not use /tmp for storage, /tmp here is just
# example sakes.
dataDir=/tmp/zookeeper
# the port at which the clients will connect
clientPort=2181
# the maximum number of client connections.
# increase this if you need to handle more clients
#maxClientCnxns=60
#
# Be sure to read the maintenance section of the
# administrator guide before turning on autopurge.
#
# http://zookeeper.apache.org/doc/current/zookeeperAdmin.html#sc_maintenance
#
# The number of snapshots to retain in dataDir
#autopurge.snapRetainCount=3
# Purge task interval in hours
# Set to "0" to disable auto purge feature
#autopurge.purgeInterval=1
- 修改以下内容
dataDir=/usr/local/zookeeper/data 保存数据目录
dataLogDir=/usr/local/zookeeper/logs 保存日志目录
server.1=192.168.92.131:2888:3888
1.2888 端口号是zookeeper服务之间通信的端口
2.3888 是zookeeper 与其他应用程序通信的端口
3.initLimit:这个配置项是用来配置 Zookeeper 接受客户端(这里所说的客户端不是用户连接 Zookeeper服务器的客户端,而是 Zookeeper 服务器集群中连接到 Leader 的 Follower 服务器)初始化连接时最长能忍受多少个心跳时间间隔数。当已经超过 10 个心跳的时间(也就是 tickTime)长度后 Zookeeper 服务器还没有收到客户端的返回信息,那么表明这个客户端连接失败。总的时间长度就是 52000=10 秒。
4.syncLimit:这个配置项标识 Leader 与 Follower 之间发送消息,请求和应答时间长度,最长不能超过多少个 tickTime 的时间长度,总的时间长度就是 22000=4 秒
5.server.A=B:C:D:其中 A 是一个数字,表示这个是第几号服务器;B 是这个服务器的IP地址或/etc/hosts文件中映射了IP的主机名;C 表示的是这个服务器与集群中的 Leader 服务器交换信息的端口;D 表示的是万一集群中的 Leader 服务器挂了,需要一个端口来重新进行选举,选出一个新的 Leader,而这个端口就是用来执行选举时服务器相互通信的端口。如果是伪集群的配置方式,由于 B 都是一样,所以不同的 Zookeeper 实例通信端口号不能一样,所以要给它们分配不同的端口号。
- 如果是配置集群环境,还需要在前面配置过的dataDir路径下新增myid文件
touch myid
vim myid
ps:在data目录下创建文件,文件名为“myid”, 编辑该“myid”文件,并在对应的IP的机器上输入对应的编号。
如在192.168.92.131上,“myid”文件内容就是1。在192.168.92.132上,内容就是2。
- 设置环境变量
export ZOOKEEPER_INSTALL=/usr/zookeeper/zookeeper-3.4.13
export PATH=$PATH:$ZOOKEEPER_INSTALL/bin
- 在zookeeper-3.4.13/bin 目录下执行以下代码启动zookeeper
./zkServer.sh start
- 启动成功效果
ZooKeeper JMX enabled by default
Using config: /usr/zookeeper/zookeeper-3.4.13/bin/../conf/zoo.cfg
Starting zookeeper ... STARTED
- 可以输入jps命令查看进程
2305 Jps
2260 QuorumPeerMain
其中,QuorumPeerMain 是 zookeeper 进程,启动正常
- 配置开机启动
- 编辑/etc/rc.local 文件,加入
su - root-c '/usr/zookeeper/zookeeper-3.4.13/bin/zkServer.sh start'
- 到此就大功告成啦。