ZooKeeper 的环境搭建
搭建-安装JDK
安装Zookeeper之前,我们需要安装JDK,JDK的安装在实验一已经介绍,本实验的环境已经默认安装了JDK,只需要按照下面的安装步骤即可安装Zookeeper。
安装步骤
1、切换到zookeeper压缩包所在位置,解压文件
cd /opt/
tar -zxvf /opt/zookeeper-3.4.9.tar.gz -C /opt
data:image/s3,"s3://crabby-images/6e202/6e202d3bf5fb89dd97d049dd5d0d9b40aeea113c" alt=""
data:image/s3,"s3://crabby-images/a07a9/a07a94f25cef5a115f81c5def3f6e1c13ef86e15" alt=""
2、创建data和log文件
2.1、切换到zookeeper的安装目录下。
cd /opt/zookeeper-3.4.9/
data:image/s3,"s3://crabby-images/1c889/1c889d33e0e0138b6b8cd95f0c56bb78ba99fca0" alt=""
2.2、在目录下新建一个data的文件夹。
mkdir data
data:image/s3,"s3://crabby-images/39ccb/39ccb98afde4286fccfe4f2c8321deacf14460a8" alt=""
2.3、在目录下面新建一个log的文件夹。
mkdir log
data:image/s3,"s3://crabby-images/b9096/b9096949dbf8133b3fa5b151d03e4865790b36ac" alt=""
3、修改zookeeper配置文件
3.1、切换到/opt/zookeeper-3.4.9/data目录下。
data:image/s3,"s3://crabby-images/7d70a/7d70a5b57af4647ec728e6ae8ec80bdda3b1c042" alt=""
3.2、在该目录下,创建一个myid的文件。
touch myid
data:image/s3,"s3://crabby-images/5e814/5e814cba6f54478d70e59b7fb6b4b80253de3e81" alt=""
3.3、编辑/opt/zookeeper-3.4.9/data目录下的myid文件
在master节点下,编辑myid文件。
vim myid
data:image/s3,"s3://crabby-images/5b719/5b7195a092f65f41c096054d8b61a0dcb96cd2da" alt=""
这里指定master的id为1。
data:image/s3,"s3://crabby-images/9b65a/9b65a28f294970e04ff78f5fd5ed4a5534b03a03" alt=""
4、重命名/opt/zookeeper-3.4.9/conf目录下的zoo_sample.cfg文件为zoo.cfg,并编辑zoo.cfg文件。
4.1、切换到zoo_sample.cfg文件所在的目录
cd /opt/zookeeper-3.4.9/conf
data:image/s3,"s3://crabby-images/af28e/af28e1d88eaae6240329b06648ebb4d5cf5bdd4b" alt=""
4.2、重命名zoo_sample.cfg文件为zoo.cfg
mv zoo_sample.cfg zoo.cfg
data:image/s3,"s3://crabby-images/94f65/94f652c87fdf8736bcdb885d93ce90b3c4e52fbb" alt=""
4.3、编辑zoo.cfg文件。
vim zoo.cfg
data:image/s3,"s3://crabby-images/f505c/f505c661082c0bdc948506e3a70a29a1f74c25e4" alt=""
data:image/s3,"s3://crabby-images/7b1b7/7b1b703c5a5ed3aab15935781421ec5615f9e0f3" alt=""
5、复制master节点的zookeeper-3.4.9文件夹到slave1节点的/opt目录下。(复制时,如果没有配置免密码登录,则会被要求输入密码,默认slave1的密码是123456
)。
scp -r /opt/zookeeper-3.4.9 root@192.168.1.3:/opt
data:image/s3,"s3://crabby-images/0b61f/0b61f1876a36c480e9303522e316e621ee8875f8" alt=""
6、复制master节点的zookeeper-3.4.9文件夹到slave2节点的/opt目录下。(复制时,如果没有配置免密码登录,则会被要求输入密码,默认slave2的密码是123456)。
scp -r /opt/zookeeper-3.4.9 root@192.168.1.4:/opt
data:image/s3,"s3://crabby-images/549e9/549e9a97b8e59c2967b08dbc9d0ef3045380ef78" alt=""
7、切换到slave1节点,修改slave1节点下面的myid文件,将slave1的id修改为2。
7.1、切换到slave1节点下面的/opt/zookeeper-3.4.9/data目录下
cd /opt/zookeeper-3.4.9/data/
data:image/s3,"s3://crabby-images/50ae1/50ae127af19eb04e569e702bef87a3a08d3d4e1a" alt=""
7.2、编辑该目录下的myid文件
vim myid
data:image/s3,"s3://crabby-images/9a03f/9a03f936f52ac22d9b4ec5c4dd7c5712f913a6c6" alt=""
data:image/s3,"s3://crabby-images/a8236/a8236a61365426f24a27b8dc366f36f219fe8581" alt=""
8、切换到slave2节点,修改slave2节点下面的myid文件,将slave2的id修改为3。
8.1、切换到slave2节点下面的/opt/zookeeper-3.4.9/data目录下
cd /opt/zookeeper-3.4.9/data/
data:image/s3,"s3://crabby-images/19dae/19daeddf3e761537a05a4cd133a94185923a2da8" alt=""
8.2、编辑改目录下的myid文件
vim myid
data:image/s3,"s3://crabby-images/675a3/675a3926d7b2b7640a443671d49b3d092d449fe6" alt=""
data:image/s3,"s3://crabby-images/a02ea/a02ea4224484818fffc088772b2c990272c19490" alt=""
启动zookeeper
注:三个节点都执行如下操作,以master为例。
1、切换到安装目录的bin目录下(/opt/zookeeper-3.4.9/bin/)
data:image/s3,"s3://crabby-images/2e48d/2e48d678bb0c3412433d80e7d848434f26dea728" alt=""
2、执行启动命令
./zkServer.sh start
data:image/s3,"s3://crabby-images/b9b46/b9b469d3440faba4926613db7c6dde9301cc64f5" alt=""
jps查看zookeeper进程
Master节点下:
jps
data:image/s3,"s3://crabby-images/32833/32833752b7c471b7481372d776fec7fa8463be4b" alt=""
Slave1节点下:
jps
data:image/s3,"s3://crabby-images/e4b3f/e4b3fc0e7e45ce40ad9aba6b34dbf1bd2f14fcdf" alt=""
Slave2节点下:
jps
data:image/s3,"s3://crabby-images/7d047/7d04734946eabeaa67a2ccdce6f0bbf8c6d28d76" alt=""
检查运行状态
1、切换到安装目录的bin目录下(/opt/zookeeper-3.4.9/bin/)
cd /opt/zookeeper-3.4.9/bin/
data:image/s3,"s3://crabby-images/6109e/6109e0ba4cb7f65334730f729512af0563184f55" alt=""
2、检查运行状态
Master节点:
./zkServer.sh status
data:image/s3,"s3://crabby-images/cb436/cb436f0093b54c30a9a1b75c3d41365a6ad59402" alt=""
Slave1节点:
./zkServer.sh status
data:image/s3,"s3://crabby-images/06c2a/06c2adc5262396a07c3f97607467f911a9a0407d" alt=""
Slave2节点:
./zkServer.sh status
data:image/s3,"s3://crabby-images/84775/84775d7b96a2b5782cfb8fe9e8e44d95c078ef57" alt=""
客户端连接测试
对于客户端来说,ZooKeeper是一个整体(ensemble),无论连接到那个节点,实际上都在独享整个ZooKeeper集群的服务,所以,我们可以在任何一个结点上建立到服务集群的连接。
1、采用zkCli.sh -server master:2181连接到ZeeKeeper。
zkCli.sh -server master:2181
[图片上传中...(image-436c57-1509675092309-3)]
2、退出连接
quit
[图片上传中...(image-4cd1af-1509675092309-2)]
停止zookeeper
注:三台节点都执行如下操作,以master为例。
1、切换到安装目录的bin目录下(/opt/zookeeper-3.4.9/bin)
cd /opt/zookeeper-3.4.9/bin/
data:image/s3,"s3://crabby-images/dc5f8/dc5f8307787461362cc7e372a1a6bc9b9bb91370" alt=""
2、执行停止命令
./zkServer.sh stop
[图片上传中...(image-9cd07-1509675092309-0)]
小结:
在我们启动zookeeper时,返回消息表明zookeeper已经启动,但是检查状态时发现,zookeeper并没有运行。
解决办法:
在/opt/zookeeper-3.4.9/bin目录下查看zookeeper.out日志文件。