一、zookeeper 介绍

 

  ZooKeeper 是一个为分布式应用所设计的分布的、开源的协调服务。它的文件系统使用我们所熟悉的目录树结构。ZooKeeper 使用 Java 所编写,但是支持 Java 和 C 两种编程语言。我们设计 ZooKeeper 的目的是为了减轻分布式应用程序所承担的协调任务。

 

二、zookeeper的安装

 首先linux系统需要安装jdk8

下载:apache-zookeeper-3.4.14.tar,上传至服务器

单机模式:通俗,就是只安装在同一台机子上面 

 

解压:

tar -xvf apache-zookeeper-3.4.14.tar.gz

 

删除安装包:

rm -rf apache-zookeeper-3.4.14.tar.gz

 

重命名:

 

zookeeper的安装 zookeeper的安装包是不是就是jar包_zookeeper的安装

 

配置环境变量:

export ZOOKEEPER_HOME=/home/linewell/zookeeper
export PATH=$JAVA_HOME/bin:$ZOOKEEPER_HOME/bin:$PATH
source /etc/profile

 

配置zookeeper

zookeeper的安装 zookeeper的安装包是不是就是jar包_apache_02

 

修改配置文件的名字:

zookeeper的安装 zookeeper的安装包是不是就是jar包_apache_03

 

创建data目录:

zookeeper的安装 zookeeper的安装包是不是就是jar包_apache_04

 

配置zookeeper:

 

vim zoo.cfg

 

tickTime:心跳时间,为了确保连接存在的,以毫秒为单位,最小超时时间为两个心跳时间
initLimit:多少个心跳时间内,允许其他server连接并初始化数据,如果ZooKeeper管理的数据较大,则应相应增大这个值
clientPort:服务的监听端口
dataDir:用于存放内存数据库快照的文件夹,同时用于集群的myid文件也存在这个文件夹里(注意:一个配置文件只能包含一个dataDir字样,即使它被注释掉了。)
dataLogDir:用于单独设置transaction log的目录,transaction log分离可以避免和普通log还有快照的竞争
syncLimit:多少个tickTime内,允许follower同步,如果follower落后太多,则会被丢弃。

server.A=B:C:D:
A是一个数字,表示这个是第几号服务器,B是这个服务器的ip地址
C第一个端口用来集群成员的信息交换,表示的是这个服务器与集群中的Leader服务器交换信息的端口
D是在leader挂掉时专门用来进行选举leader所用

 

配置如下:

# 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=0
#
minSessionTimeout=4000
maxSessionTimeout=10000
# 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

server.1=ip:2888:3888

 

zookeeper的安装 zookeeper的安装包是不是就是jar包_apache_05

 

启动:

/home/linewell/zookeeper/bin/zkServer.sh start /home/linewell/zookeeper/conf/zoo.cfg

zookeeper的安装 zookeeper的安装包是不是就是jar包_zookeeper_06

 

 

 

查看状态:

zkServer.sh status

 

 

zookeeper的安装 zookeeper的安装包是不是就是jar包_zookeeper的安装_07

 

启动报错:

切换成前台启动:

./bin/zkServer.sh start-foreground

 

然后就可以查看打印的信息。

 

搭建zookeeper集群,搭建zookeeper集群的方式和单机的方式大同小异。需要在datadir所指向的目录创建一个叫做myid的文件。上面写下当前服务器的编号。

zookeeper的安装 zookeeper的安装包是不是就是jar包_apache_08

 

然后myid里面写下当前服务器的编号。然后配置到zoo.cfg当中。

 zoo.cfg的服务器配置:

server.1=ip:2888:3888
server.2=ip:2888:3888

 

 

zookeeper 四字命令的使用

 

先yum安装nc

yum install -y nc

 

zookeeper的安装 zookeeper的安装包是不是就是jar包_服务器_09

 

然后测试:

 

zookeeper的安装 zookeeper的安装包是不是就是jar包_zookeeper的安装_10

 

 就可以得到配置信息了。

 

zookeeper的命令行工具使用

 

输入

zkCli.sh –server 10.77.20.23:2181

进入命令行工具

 

输入 help 之后,屏幕会输出可用的 ZooKeeper 命令

zookeeper的安装 zookeeper的安装包是不是就是jar包_服务器_11

 

相关命令使用:

 

查看特定的路径下,的节点信息,就是查兰特定路径下的节点:

zookeeper的安装 zookeeper的安装包是不是就是jar包_apache_12

 

创建一个节点,并添加数据:

zookeeper的安装 zookeeper的安装包是不是就是jar包_zookeeper的安装_13

 

查看节点的字符串信息:

zookeeper的安装 zookeeper的安装包是不是就是jar包_服务器_14

 

 重置节点的字符串信息:

zookeeper的安装 zookeeper的安装包是不是就是jar包_zookeeper的安装_15

然后从新查看,可以发现,已经被重置了。

 

delete操作删除对应的节点:

 

zookeeper的安装 zookeeper的安装包是不是就是jar包_apache_16

 

删除后用ls命令查看,发现没有了对应的节点了。 

 

zookeeper相关的api介绍:

maven依赖:

<dependency>
    <groupId>org.apache.zookeeper</groupId>
    <artifactId>zookeeper</artifactId>
    <version>3.4.13</version>
</dependency>

 

demo:

 

 

 

zookeeper的安装 zookeeper的安装包是不是就是jar包_服务器_17