zookeeper部署教程

在Linux系统中离线安装并配置ZooKeeper,可按以下步骤操作:

1. 准备安装包和依赖

  • 下载ZooKeeper :在有网络的环境下,前往Apache ZooKeeper官网下载所需的稳定版本,例如zookeeper-3.8.2.tar.gz
  • 准备JDK :ZooKeeper依赖Java运行环境,下载适合Linux系统的JDK安装包,如jdk-11.0.15_linux-x64_bin.tar.gz
  • 将下载好的ZooKeeper和JDK安装包复制到离线的Linux系统中。

2. 安装JDK

bash 复制代码
# 解压JDK安装包
tar -zxvf jdk-11.0.15_linux-x64_bin.tar.gz
# 移动解压后的JDK目录到指定位置
sudo mv jdk-11.0.15 /usr/local/
# 配置环境变量,编辑~/.bashrc文件
vi ~/.bashrc

在文件末尾添加以下内容:

plaintext 复制代码
export JAVA_HOME=/usr/local/jdk-11.0.15
export PATH=$JAVA_HOME/bin:$PATH

使环境变量生效:

bash 复制代码
source ~/.bashrc

验证Java安装:

bash 复制代码
java -version

3. 安装ZooKeeper

bash 复制代码
# 解压ZooKeeper安装包
tar -zxvf zookeeper-3.8.2.tar.gz
# 移动解压后的ZooKeeper目录到指定位置
sudo mv zookeeper-3.8.2 /usr/local/zookeeper

4. 配置ZooKeeper

bash 复制代码
# 进入ZooKeeper配置目录
cd /usr/local/zookeeper/conf
# 复制示例配置文件
cp zoo_sample.cfg zoo.cfg
# 编辑zoo.cfg文件
vi zoo.cfg

zoo.cfg中可进行如下常见配置修改:

plaintext 复制代码
# 数据存储目录
dataDir=/var/lib/zookeeper
# 日志存储目录
dataLogDir=/var/log/zookeeper
# 客户端连接端口
clientPort=2181
# 初始连接时的心跳数
initLimit=5
# 同步连接时的心跳数
syncLimit=2

创建数据和日志目录:

bash 复制代码
sudo mkdir -p /var/lib/zookeeper
sudo mkdir -p /var/log/zookeeper
复制代码
sudo chmod 644 /usr/local/zookeeper/conf/zoo.cfg

5. 配置系统服务(可选但推荐)

复制代码
[linux]# readlink -f $(which java)
/BOCO/java-se-8u43-ri/bin/java

创建ZooKeeper的Systemd服务文件:

bash 复制代码
sudo vi /etc/systemd/system/zookeeper.service

在文件中添加以下内容:

plaintext 复制代码
[Unit]
Description=Apache ZooKeeper server
Documentation=http://zookeeper.apache.org
Requires=network.target remote-fs.target
After=network.target remote-fs.target

[Service]
Type=simple
Environment=JAVA_HOME=/BOCO/java-se-8u43-ri
ExecStart=/usr/local/zookeeper/bin/zkServer.sh start-foreground
ExecStop=/usr/local/zookeeper/bin/zkServer.sh stop
Restart=on-abnormal

[Install]
WantedBy=multi-user.target

重新加载Systemd管理器配置:

bash 复制代码
sudo systemctl daemon-reload

可能遇到的情况

1.脚本权限不足

zkServer.sh 脚本可能没有执行权限。

使用以下命令为 zkServer.sh 脚本添加执行权限:

bash

复制代码
chmod +x /usr/local/zookeeper/bin/zkServer.sh
2.服务文件语法错误

zookeeper.service 文件可能存在语法错误。

使用以下命令检查服务文件语法:

复制代码
sudo systemd-analyze verify zookeeper.service

6. 启动和验证ZooKeeper

使用以下命令开放端口:

复制代码
sudo firewall-cmd --zone=public --add-port=2181/tcp --permanent
sudo firewall-cmd --reload

启动ZooKeeper服务:

bash 复制代码
sudo systemctl start zookeeper

设置ZooKeeper开机自启:

bash 复制代码
sudo systemctl enable zookeeper

检查ZooKeeper服务状态:

bash 复制代码
sudo systemctl status zookeeper

使用ZooKeeper客户端连接到服务器进行验证:

bash 复制代码
/usr/local/zookeeper/bin/zkCli.sh -server localhost:2181

通过以上步骤,你可以在离线的Linux系统中完成ZooKeeper的安装和配置。

相关推荐
潘多编程7 小时前
SpringBoot分布式项目订单管理实战:Mybatis最佳实践全解
spring boot·分布式·mybatis
东阳马生架构8 小时前
zk基础—1.一致性原理和算法
zookeeper
星光璀璨山河无恙10 小时前
【Hadoop】Hadoop3.1.4完全分布式集群搭建
大数据·hadoop·分布式
失业写写八股文13 小时前
本地事务 vs 分布式事务:核心区别与解释
分布式·后端
丑过三八线13 小时前
【Kafka】Kafka4.0在windows上启动
windows·分布式·kafka
dengjiayue14 小时前
kafka 与 RocketMQ对比
分布式·kafka·rocketmq
Lansonli15 小时前
大数据Spark(五十六):Spark生态模块与运行模式
大数据·分布式·spark
hf20001215 小时前
技术深度报道:解析云器Lakehouse如何实现超越Spark 10倍性能提升
大数据·分布式·spark
快来卷java15 小时前
RabbitMQ 技术详解:异步消息通信的核心原理与实践
java·分布式·rabbitmq