(三)Kafka离线安装 - ZooKeeper开机自启

手动启动方式

一般通过指令手动来启动zookeeper的方法是,先进入到zookeeper的安装目录下的bin目录,然后执行启动指令。

bash 复制代码
cd /usr/local/zookeeper/zookeeper-3.8.4/bin/

zkServer.sh start

停止指令

bash 复制代码
zkServer.sh stop

查看状态

bash 复制代码
zkServer.sh status

上面的方式是通过手动启动,关闭的。如果系统重启了,zookeeper服务是不会自动启动的。

这里是通过创建系统服务,然后把这个系统服务设置开机自启,从而达到想要的目的。

下面开始教你怎么把zookeeper创建为系统服务。

系统服务启动方式

1、创建一个服务单元文件 /etc/systemd/system/zookeeper.service

bash 复制代码
#先进入到此目录下
cd /etc/systemd/system/

#创建一个zookeeper.service服务单元文件
vim zookeeper.service

2、zookeeper.service服务单元文件内容

bash 复制代码
[Unit]
Description=Apache Zookeeper Server
After=network.target remote-fs.target nss-lookup.target

[Service]
Type=forking
User=root
Group=root
ExecStart=/usr/local/zookeeper/zookeeper-3.8.4/bin/zkServer.sh start
ExecStop=/usr/local/zookeeper/zookeeper-3.8.4/bin/zkServer.sh stop
ExecReload=/usr/local/zookeeper/zookeeper-3.8.4/bin/zkServer.sh restart
Restart=on-failure

[Install]
WantedBy=multi-user.target

ExecStart后面跟的是zookeeper的启动指令,关于文件路径替换为自己的就行。

ExecStop后面跟的是zookeeper的停止指令,关于文件路径替换为自己的就行。

ExecReload后面跟的是zookeeper的重启指令,关于文件路径替换为自己的就行。

设置权限

bash 复制代码
chmod 777 zookeeper.service

重新加载systemctl管理器配置,使新的服务单元生效

bash 复制代码
systemctl daemon-reload

systemctl 相关指令

bash 复制代码
# 设置服务开机自启
systemctl enable zookeeper.service
# 取消开机自启
systemctl disable  zookeeper.service

# 启动服务
systemctl start zookeeper

# 停止服务
systemctl stop zookeeper

# 重启服务
systemctl restart zookeeper

# 查看服务状态
systemctl status zookeeper

# 查看服务是否开机自启
systemctl is-enabled zookeeper

遇到的问题

当执行 systemctl start zookeeper 启动服务时,没有启动成功。

需要在zkEnv.sh文件中添加JDK的JAVA_HOME路径。

bash 复制代码
cd /usr/local/zookeeper/zookeeper-3.8.4/bin/

vim zkEnv.sh

至此,重新启动,启动成功。

相关推荐
lhbian2 小时前
PHP、C++和C语言对比:哪个更适合你?
android·数据库·spring boot·mysql·kafka
Jackyzhe4 小时前
从零学习Kafka:认证机制
分布式·学习·kafka
lhbian5 小时前
PHP vs Java vs Go:编程语言终极对比
java·spring boot·后端·kafka·linq
AutoMQ5 小时前
别再每月浪费数千美元:拆解 AWS/GCP Kafka 背后的隐性账单
kafka·消息队列·aws
Devin~Y8 小时前
大厂Java面试实战:Spring Boot/WebFlux、Redis+Kafka、K8s可观测性与Spring AI RAG/Agent三轮连环问
java·spring boot·redis·kafka·kubernetes·resilience4j·spring webflux
indexsunny9 小时前
互联网大厂Java求职面试实战:Spring Boot与微服务架构解析
java·spring boot·redis·kafka·spring security·flyway·microservices
ldj202011 小时前
kafka如何合理分配消费者数量和分区数量
kafka
蓝魔Y12 小时前
Apache—Kafka实践
分布式·kafka·apache
__土块__1 天前
Java 大厂一面模拟:从线程本地存储到分库分表路由的连环拷问
kafka·线程池·分库分表·java面试·threadlocal·缓存一致性·大厂一面
面向Google编程1 天前
从零学习Kafka:认证机制
大数据·kafka