在CentOS上部署Zookeeper的高可用方案,通常涉及多个节点的配置,以确保即使某个节点发生故障,Zookeeper集群仍然可以正常运行。以下是一个基本的步骤指南:
sudo yum install java-1.8.0-openjdk-devel
在每个节点上下载并解压Zookeeper。
wget https://archive.apache.org/dist/zookeeper/zookeeper-3.7.0/apache-zookeeper-3.7.0-bin.tar.gz
tar -xzvf apache-zookeeper-3.7.0-bin.tar.gz -C /opt
在每个节点上创建Zookeeper的数据目录和日志目录。
sudo mkdir -p /var/lib/zookeeper/data
sudo mkdir -p /var/log/zookeeper
编辑/opt/apache-zookeeper-3.7.0-bin/conf/zoo.cfg
文件,添加以下内容:
tickTime=2000
dataDir=/var/lib/zookeeper/data
clientPort=2181
initLimit=5
syncLimit=2
server.1=node1:2888:3888
server.2=node2:2888:3888
server.3=node3:2888:3888
在每个节点的/var/lib/zookeeper/data
目录下创建一个myid
文件,内容为该节点的ID(例如,node1的myid
文件内容为1)。
echo "1" | sudo tee /var/lib/zookeeper/data/myid # 在node1上
echo "2" | sudo tee /var/lib/zookeeper/data/myid # 在node2上
echo "3" | sudo tee /var/lib/zookeeper/data/myid # 在node3上
在每个节点上启动Zookeeper服务。
/opt/apache-zookeeper-3.7.0-bin/bin/zkServer.sh start
使用zkServer.sh status
命令检查每个节点的状态。
/opt/apache-zookeeper-3.7.0-bin/bin/zkServer.sh status # 在node1上
/opt/apache-zookeeper-3.7.0-bin/bin/zkServer.sh status # 在node2上
/opt/apache-zookeeper-3.7.0-bin/bin/zkServer.sh status # 在node3上
你应该看到类似以下的输出,表示集群正常运行:
ZooKeeper JMX enabled by default
Using config: /opt/apache-zookeeper-3.7.0-bin/conf/zoo.cfg
Mode: follower
确保防火墙允许Zookeeper的端口(默认是2181、2888和3888)。
sudo firewall-cmd --permanent --zone=public --add-port=2181/tcp
sudo firewall-cmd --permanent --zone=public --add-port=2888/tcp
sudo firewall-cmd --permanent --zone=public --add-port=3888/tcp
sudo firewall-cmd --reload
配置监控和日志记录,以便及时发现和解决问题。可以使用Zookeeper自带的四字命令进行监控。
/opt/apache-zookeeper-3.7.0-bin/bin/zkCli.sh -server node1:2181
然后输入以下命令查看集群状态:
stat
通过以上步骤,你可以在CentOS上部署一个高可用的Zookeeper集群。确保每个节点都正确配置,并且网络连接正常。定期检查和维护集群,以确保其稳定运行。