一、解压安装 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
/***
* ,%%%%%%%%,
* ,%%/\%%%%/\%%
* ,%%%\c "" J/%%%
* %. %%%%/ o o \%%%
* `%%. %%%% _ |%%%
* `%% `%%%%(__Y__)%%'
* // ;%%%%`\-/%%%'
* (( / `%%%%%%%'
* \\ .' |
* \\ / \ | |
* \\/ ) | |
* \ /_ | |__
* (___________))))))) 攻城湿
*/