在Linux上搭建Zookeeper高可用集群需要遵循以下步骤:
在每个节点上执行以下命令:
wget https://downloads.apache.org/zookeeper/zookeeper-3.7.0/apache-zookeeper-3.7.0-bin.tar.gz
tar -xzvf apache-zookeeper-3.7.0-bin.tar.gz
cd apache-zookeeper-3.7.0-bin
在每个节点上创建一个配置文件zoo.cfg,并进行相应的配置。以下是一个基本的配置示例:
tickTime=2000
dataDir=/var/lib/zookeeper
clientPort=2181
initLimit=5
syncLimit=2
server.1=node1:2888:3888
server.2=node2:2888:3888
server.3=node3:2888:3888
tickTime:基本时间单位(毫秒)。dataDir:数据存储目录。clientPort:客户端连接端口。initLimit:允许follower连接并同步到leader的最大时间。syncLimit:允许follower与leader同步的最大时间。server.X:定义集群中的服务器,X是服务器ID,格式为server.ID=hostname:peerPort:leaderElectionPort。在每个节点的dataDir目录下创建一个名为myid的文件,并写入该节点的ID(与zoo.cfg中的server.X中的X一致)。
echo "1" > /var/lib/zookeeper/myid # 在node1上
echo "2" > /var/lib/zookeeper/myid # 在node2上
echo "3" > /var/lib/zookeeper/myid # 在node3上
在每个节点上启动Zookeeper服务:
bin/zkServer.sh start
在任意一个节点上执行以下命令来验证集群状态:
bin/zkServer.sh status
你应该能看到类似以下的输出,表示集群已经正常运行:
ZooKeeper JMX enabled by default
Using config: /var/lib/zookeeper/conf/zoo.cfg
Mode: follower
确保防火墙允许Zookeeper的端口(默认是2181、2888和3888)通信。例如,在CentOS上可以使用以下命令:
firewall-cmd --zone=public --add-port=2181/tcp --permanent
firewall-cmd --zone=public --add-port=2888/tcp --permanent
firewall-cmd --zone=public --add-port=3888/tcp --permanent
firewall-cmd --reload
bin/zkCli.sh -server node1:2181 ls /
dataDir目录下的zookeeper.out)以发现潜在问题。通过以上步骤,你可以在Linux上成功搭建一个Zookeeper高可用集群。