在CentOS系统上配置Zookeeper的Java环境涉及几个关键步骤。以下是详细的配置指南:
首先,确保你的系统上已经安装了Java运行环境(JRE)或Java开发工具包(JDK)。推荐安装OpenJDK 8或更高版本。
sudo yum install java-1.8.0-openjdk-devel
安装完成后,检查Java是否安装成功:
java -version
从Apache Zookeeper官方网站下载适合CentOS的版本。例如,下载zookeeper-3.4.14版本:
wget https://archive.apache.org/dist/zookeeper/zookeeper-3.4.14/zookeeper-3.4.14.tar.gz
tar -zxvf zookeeper-3.4.14.tar.gz -C /usr/local/
编辑 /etc/profile 文件,追加以下内容:
export JAVA_HOME=/usr/java/jdk1.8.0_111
export JRE_HOME=$JAVA_HOME/jre
export PATH=$JAVA_HOME/bin:$JRE_HOME/bin
export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
export ZOOKEEPER_HOME=/usr/local/zookeeper-3.4.9
export PATH=$ZOOKEEPER_HOME/bin:$PATH
使修改生效:
source /etc/profile
进入解压后的Zookeeper目录:
cd /usr/local/zookeeper-3.4.9/conf
cp zoo_sample.cfg zoo.cfg
编辑 zoo.cfg 文件,设置以下参数:
tickTime 2000
dataDir /usr/local/zookeeper-3.4.9/data
clientPort 2181
initLimit 5
syncLimit 2
server.1 192.168.0.1:2888:3888
server.2 192.168.0.12:2888:3888
server.3 192.168.0.13:2888:3888
在每台服务器上创建数据存储目录:
sudo mkdir /usr/local/zookeeper-3.4.9/data
确保Zookeeper用户具有对这些目录的读写权限。
在每台服务器的 dataDir 目录下创建一个名为 myid 的文件,内容为该服务器的唯一ID(例如,Master节点的ID为1,Slave节点的ID为2):
echo "1" > /usr/local/zookeeper-3.4.9/data/myid
为了确保Zookeeper服务在系统启动时自动运行,需要将其添加到系统服务并设置开机自启。
创建并编辑 zookeeper.service 文件:
sudo vi /etc/systemd/system/zookeeper.service
添加以下内容:
[Unit]
Description=Zookeeper Service
After=network.target
[Service]
Type=forking
ExecStart=/usr/local/zookeeper-3.4.9/bin/zkServer.sh start
ExecStop=/usr/local/zookeeper-3.4.9/bin/zkServer.sh stop
PrivateTmp=true
Environment=JAVA_HOME=/usr/java/jdk1.8.0_111
User=zookeeper
Group=zookeeper
PIDFile=/var/run/zookeeper/zookeeper.pid
Restart=always
[Install]
WantedBy=multi-user.target
使配置生效:
sudo systemctl daemon-reload
sudo systemctl enable zookeeper.service
sudo systemctl start zookeeper.service
启动Zookeeper服务:
/usr/local/zookeeper-3.4.9/bin/zkServer.sh start
验证Zookeeper状态:
/usr/local/zookeeper-3.4.9/bin/zkServer.sh status
开放Zookeeper使用的端口(默认是2181):
sudo vi /etc/firewalld/rules.d/zookeeper.rules
添加以下内容:
port=2181
protocol=tcp
allow=in
重启防火墙:
sudo firewall-cmd --reload
使用Zookeeper客户端工具验证连接:
sudo yum install zookeeper-client
zkCli
列出根节点:
ls /
通过以上步骤,您应该能够在CentOS系统上成功配置并运行Zookeeper。请根据您的实际需求调整配置参数。