Zookeeper集群搭建记录 | 云计算[CentOS7] | Zookeeper集群搭建
写在前面本系列文章索引以及一些默认好的条件在 传送门在配置Zookeeper之前,建议先配置Hadoop集群,具体的操作流程博主已更新完成,链接step1 Zookeeper安装包的下载Zookeeper的安装包版本不太相同,大致分为有编译过的和没有编译过的(如有错请留言指正一般情况下对于我们在解压配置就能使用的情况下,我们可以下载编译之后的版本,比如在官网上:下面代表着源代码,我们应该选择不在红
本文目录
写在前面
本系列文章索引以及一些默认好的条件在 传送门
在配置Zookeeper之前,建议先配置Hadoop集群,具体的操作流程博主已更新完成,链接
step1 Zookeeper安装包的下载
Zookeeper的安装包版本不太相同,大致分为有编译过的和没有编译过的(如有错请留言指正
一般情况下对于我们在解压配置就能使用的情况下,我们可以下载编译之后的版本,比如在官网上:
下面代表着源代码,我们应该选择不在红框之内的
Zookeeper仓库
本文以3.5.9为例,应该下载上方连接中的:
这个版本的解压后和其他未编译过的有个显著的不同:在解压后有一个lib文件夹,通常里面保存着应该会用到的文件等
下载速度较快,不再网盘分享
step2 关闭防火墙
如果防火墙处于打开的状态,会影响到虚拟机之间的互相访问,以及从主机通过web浏览器查看各个服务器节点的状态
命令:
systemctl stop firewalld
systemctl disable firewalld
systemctl status firewalld
step3 解压配置Zookeeper
1 解压并创建修改/conf/zoo.cfg文件
将下载好的文件放到master节点的/usr/local/
之下
然后解压文件,命令:
tar -zxvf apache-zookeeper-3.5.9-bin.tar.gz
解压之后,将文件夹的名字去掉版本号:
mv apache-zookeeper zookeeper
然后跳转到./zookeeper/conf
下,将官方给的zoo.cfg示例文件改名:
cp zoo_sample.cfg zoo.cfg
然后编辑zoo.cfg
大致改为:
切勿盲目CV,记得修改为自己的主机名
# 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=/usr/local/zookeeper/data/
# the port at which the clients will connect
clientPort=2181
# master
server.1=0.0.0.0:2881:3881
server.2=slave01-315:2881:3881
server.3=slave02-315:2881:3881
2 创建并修改/data/myid
在zookeeper根目录下,我们再创建一个data文件夹
mkdir -p /usr/local/zookeeper/data
然后创建并编辑myid
文件
cd /usr/local/zookeeper/data
touch myid
vim myid
在master节点的myid中,写入一个数字1
注意不得加任何空格,任何注释,必须单纯一行一列一个字符’1’
step4 配置文件传送到其他节点
我们需要将从master的文件放到slave1,slave2上
scp -r /usr/local/zookeeper slave1:/usr/local
scp -r /usr/local/zookeeper slave2:/usr/local
在slave1上,我们需要把/data/myid
中的内容改为2
在slave2上,我们需要把/data/myid
中的内容改为3
注意不得加任何空格,任何注释,必须单纯一行一列一个字符’1’
在slave1上,我们需要把/conf/zoo.cfg
改成:
切勿盲目CV,记得修改为自己的主机名
# 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=/usr/local/zookeeper/data/
# the port at which the clients will connect
clientPort=2181
server.1=master315:2881:3881
server.2=0.0.0.0:2881:3881
server.3=slave02-315:2881:3881
在slave2下,我们需要将/conf/zoo.cfg
文件修改为:
切勿盲目CV,记得修改为自己的主机名
# 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=/usr/local/zookeeper/data/
# the port at which the clients will connect
clientPort=2181
server.1=master315:2881:3881
server.2=slave01-315:2881:3881
server.3=0.0.0.0:2881:3881
如果是小白从头开始配的话,应该不会出现2181端口被占用的情况,如果说自己的2181端口被占用,可以kill -9该进程
查看进程是否被占用:
netstat -nltp | grep 2181
若显示空白则恭喜你不需要进行任何操作
若显示除了某进程占用该端口,应该kill -9 进程号
step5 设置环境变量
我们修改~/.bashrc
文件
vim ~/.bashrc
加入:
export PATH=$PATH:/usr/local/zookeeper/bin
然后:
source ~/.bashrc
现在应该使得该文件生效了
step6 启动zookeeper
zkServer.sh start
这时,我们查看zookeeper/data/
下的所有文件:
cd /usr/local/zookeeper/data
ls -laF
发现除了myid
还会有另外的若干文件(version-2文件夹&&zookeeper_server.pid),这是请注意:
如果不是通过命令使得zookeeper自动关闭的,在下次启动前均需删除该目录下除了myid的所有文件
在三个节点均启动zookeeper集群
启动命令是:zkServer.sh start
重启命令是:zkServer.sh restart
关闭命令是:zkServer.sh stop
查看状态命令是:zkServer.sh status
注意,在我们依次启动节点的zookeeper的过程中,可能会遇到首先启动的节点的日志文件中出现拒绝连接的情况,这时请忽略,原因是:
后续节点未启动,所以会导致和其他未开启的节点通信失败导致拒绝连接,我们应当查看最后启动zookeeper的结点的日志文件(/usr/local/zookeeper/logs/
),
step7 启动成功及状态查看
在我们成功启动集群之后,应该会看到:
master
slave1:
slave2:
出现started则证明启动成功,我们查看状态:
master:
slave1:
slave2:
在此,发现master为leader,其余两个节点为follower
这里的leader由zookeeper内部选举产生,谁是leader均有可能,不必太在意
step8 验证zookeeper安装
在每个节点均输入:jps
来查看相关进程
master:
slave1:
slave2:
到这里进本就证明安装没大问题了
但是为了严谨一点,我们测试下功能
step9 zookeeper功能测试
我们进入zookeeper的命令行工具:
红框是命令zkCli.sh -server master315:2181
在箭头所示区域输入:
create /hello world
get /hello
可以发现莫得问题,然后就可以退出了
输入:
quit
到此,Zookeeper安装结束
如有问题可以 留言 or 私信 or q_2649432030
更多推荐
所有评论(0)