简介:html
ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,是Google的Chubby一个开源的实现,是Hadoop和Hbase的重要组件。它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护、域名服务、分布式同步、组服务等。linux
ZooKeeper的目标就是封装好复杂易出错的关键服务,将简单易用的接口和性能高效、功能稳定的系统提供给用户。算法
zookeeper模式:apache
Standalone独立模式:centos
只有一个zookeeper服务实例,不可保证高可靠性和恢复性,可在测试环境中使用,生产环境不建议使用。服务器
Distributed集群模式:分布式
有多个zookeeper实例在运行,建议多个zk实例是在不一样的服务器上。集群中不一样zookeeper实例之间数据不停的同步。有半数以上的实例保持正常运行,zk服务就能正常运行,例如:有5个zk实例,挂了2个,还剩3个,依然能够正常工做;若有6个zk实例,挂了3个,则不能正常工做。ide
伪集群模式:oop
简单来讲,集群伪分布模式就是在单机下模拟集群的ZooKeeper服务。性能
本文主要讲解集群模式安装部署
1、安装环境
一、操做系统:Amazon Linux(目前版本基于centos6核心)
二、jdk-1.7.9
三、zookeeper-3.4.8
2、安装JDK
安装Zookeeper须要先安装JDK,
安装JDK参考本站博文http://linuxtech.blog.51cto.com/3670088/1706792
3、修改hosts文件
主机名称到IP地址映射配置
ZooKeeper集群中具备两个关键的角色:Leader和Follower。集群中全部的结点做为一个总体对分布式应用提供服务,集群中每一个结点之间都互相链接,因此,在配置的ZooKeeper集群的时候,每个结点的host到IP地址的映射都要配置上集群中其它结点的映射信息。
例如,个人ZooKeeper集群中每一个结点的配置,以slave-01为例,/etc/hosts内容以下所示:
192.168.0.101 slave-1
192.168.0.102 slave-2
192.168.0.103 slave-3
ZooKeeper采用一种称为Leader election的选举算法。在整个集群运行过程当中,只有一个Leader,其余的都是Follower,若是ZooKeeper集群在运行过程当中Leader出了问题,系统会采用该算法从新选出一个Leader。所以,各个结点之间要可以保证互相链接,必须配置上述映射。
ZooKeeper集群启动的时候,会首先选出一个Leader,在Leader election过程当中,某一个知足选举算的结点就能成为Leader。
4、安装并配置zookeeper
到http://zookeeper.apache.org/releases.html去下载Zookeeper,建议选择稳定版,即stable的。
tar zxvf zookeeper-3.4.8.tar.gz -C /export/Server/
cd /export/Server/
mv zookeeper-3.4.8/ zookeeper
cd zookeeper/
cp conf/zoo_sample.cfg conf/zoo.cfg
mkdir -p /export/data/zookeeper/
修改zoo.cfg配置文件
sed -i 's/dataDir=\/tmp\/zookeeper/dataDir=\/export\/data\/zookeeper/' conf/zoo.cfg
echo '''
> server.1=slave-1:2888:3888
> server.2=slave-2:2888:3888
> server.3=slave-3:2888:3888
> ''' >> conf/zoo.cfg
5、配置zookeeper的环境变量
cat >> /etc/profile <<EOF
export ZOOKEEPER_HOME=/export/Server/zookeeper
export PATH=$PATH:$ZOOKEEPER_HOME/bin
EOF
使之生效
source /etc/profile
六:远程复制分发安装文件
上面已经在一台机器slave-01上配置完成ZooKeeper,如今能够将该配置好的安装文件远程拷贝到集群中的各个结点对应的目录下:
七:设置myid
在咱们zoo.cfg配置的dataDir指定的目录下面,建立一个myid文件,里面内容为一个数字,用来标识当前主机,conf/zoo.cfg文件中配置的server.X中X是什么数字,则myid文件中就输入这个数字,例如:
[root@slave-1 /]echo "1" > /export/data/zookeeper/myid
[root@slave-2 /]echo "2" > /export/data/zookeeper/myid
[root@slave-3 /]echo "3" > /export/data/zookeeper/myid
8、启动ZooKeeper集群
在ZooKeeper集群的每一个结点上,执行启动ZooKeeper服务的脚本,以下所示:
chmod +x -R bin/
cd bin/
./zkServer.sh start
查看启动日志:
tail -500f zookeeper.out
9、查看状态
查看zookeeper集群是否启动
./zkServer.sh status
ZooKeeper JMX enabled by default
Using config: /export/Server/zookeeper/bin/../conf/zoo.cfg
Mode: follower
leader的显示是:
ZooKeeper JMX enabled by default
Using config: /export/Server/zookeeper/bin/../conf/zoo.cfg
Mode: leader
查看zookeeper的启动状态
echo ruok | nc 192.168.0.101 2181
控制台输出: imok
10、测试
经过zkCli.sh -server ip 就能够链接到其中一台server中,而后就能够经过交互式命令来控制zk了
(完)