高可用ZooKeeper集群部署

发布于:2022-12-25 ⋅ 阅读:(543) ⋅ 点赞:(0)

一、解压安装 jdk(我这里在Hadoop部署已经安装了)

tar -zxvf /opt/software/jdk-8u152-linux-x64.tar.gz -C /usr/local/src

更改 jdk 的名称

mv /usr/local/src/jdk1.8.0_152/ /usr/local/src/java

二、安装 ZooKeeper

上传zookeeper 到 opt 下

开始解压zookeeper

tar -zxvf /opt/zookeeper-3.4.8.tar.gz -C /usr/local/src/

进入刚刚解压的目录

cd /usr/local/src/

移动(修改名字)

mv zookeeper-3.4.8 zookeeper

三、创建ZooKeeper数据目录

data是用来传输数据的,logs是用来记录日志的

先返回跟目录

mkdir /usr/local/src/zookeeper/data
mkdir /usr/local/src/zookeeper/logs

任务二、ZooKeeper文件参数配置

一、设置ZooKeeper环境变量

返回目录

cd /usr/local/src/zookeeper

修改文件

vi /etc/profile

修改内容如下:

# java environment(hadoop部署的时候已配置)
# export JAVA_HOME=/usr/local/src/java #JAVA_HOME 指向 JAVA 安装目录
# export PATH=$PATH:$JAVA_HOME/bin     #将 JAVA 安装目录加入 PATH 路径
​
# zookeeper environment
export ZK_HOME=/usr/local/src/zookeeper
export PATH=$PATH:$ZK_HOME/bin

二、修改zoo.cfg配置文件

首先进入到 conf 目录下将 zoo.cfg 文件拷贝过来

cd conf/

查看有什么文件

ls

复制一份并改名

cp zoo_sample.cfg zoo.cfg

修改文件

vi zoo.cfg

并添加以下内容

#修改
dataDir=/usr/local/src/zookeeper/data
#增加
dataLogDir=/usr/local/src/zookeeper/logs
server.1=192.168.235.233:2888:3888
server.2=192.168.235.234:2888:3888
server.3=192.168.235.235:2888:3888
#上面的 IP 可以换成自己的主机地址,或者换成主机名,一般我们换成主机名保存并退出

三、创建myid配置文件

返回目录

cd ..

进入目录

cd data/

输入以下命令

echo "1" > myid

任务三、ZooKeeper集群启动

一、分发ZooKeeper集群

scp -r /usr/local/src/zookeeper/ root@slave1:/usr/local/src/

scp -r /usr/local/src/zookeeper/ root@slave2:/usr/local/src/

使文件生效

source /etc/profile

分发环境变量并使其生效

scp /etc/profile root@slave1:/etc/

到slave1 节点使文件生效

source /etc/profile

scp /etc/profile root@slave2:/etc/

到slave2 节点使文件生效

source /etc/profile

二、修改myid配置

master对应1 ,slave1对应2, slave2对应3

1、修改master的myid

2、修改slave1的myid

cd /usr/local/src/zookeeper/data/

echo "2">myid

3、修改slave2的myid

三、修改 ZooKeeper 安装目录的归属用户为hadoop用户。(这里没有创建hadoop用户,所有就不弄这一步了)

[root@master data]# chown -R hadoop:hadoop /usr/local/src/zookeeper

[root@slave1 data] # chown -R hadoop:hadoop /usr/local/src/zookeeper

[root@slave2 data] # chown -R hadoop:hadoop /usr/local/src/zookeeper

四、启动 ZooKeeper 集群

(我这里下面这一步在部署hadoop已经弄好了,防火墙就不用再弄了)

关闭防火墙

[root@master data]# systemctl stop firewalld.service

[root@slave1 data]# systemctl stop firewalld.service

[root@slave2 data]# systemctl stop firewalld.service

关闭防火墙自启

[root@master data]# systemctl disable firewalld.service

Removed symlink /etc/systemd/system/multi-user.target.wants/firewalld.service.

Removed symlink /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.

[root@slave1 data]# systemctl disable firewalld.service

Removed symlink /etc/systemd/system/multi-user.target.wants/firewalld.service.

Removed symlink /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.

[root@slave2 data]# systemctl disable firewalld.service

Removed symlink /etc/systemd/system/multi-user.target.wants/firewalld.service.

Removed symlink /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.

同时启动三个节点的 zookeeper

master节点上启动

 zkServer.sh start

slave1节点上启动

zkServer.sh start

slave2节点上启动

zkServer.sh start

查看master状态

zkServer.sh status

slave1 节点状态

zkServer.sh status

slave2 节点状态

zkServer.sh status

五、关闭进程

zkServer.sh stop

本文含有隐藏内容,请 开通VIP 后查看