《日均70亿请求项目实战》之部署三台zookeeper集群

2024-06-07 03:12

本文主要是介绍《日均70亿请求项目实战》之部署三台zookeeper集群,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

个人名片
在这里插入图片描述
🎓作者简介:java领域优质创作者
🌐个人主页:码农阿豪
📞工作室:新空间代码工作室(提供各种软件服务)
💌个人邮箱:[2435024119@qq.com]
📱个人微信:15279484656
🌐个人导航网站:www.forff.top
💡座右铭:总有人要赢。为什么不能是我呢?

  • 专栏导航:

码农阿豪系列专栏导航
面试专栏:收集了java相关高频面试题,面试实战总结🍻🎉🖥️
Spring5系列专栏:整理了Spring5重要知识点与实战演练,有案例可直接使用🚀🔧💻
Redis专栏:Redis从零到一学习分享,经验总结,案例实战💐📝💡
全栈系列专栏:海纳百川有容乃大,可能你想要的东西里面都有🤸🌱🚀

目录

  • 部署三台zookeeper集群
    • 安装Java环境
    • 准备zookeeper包
    • 上传到服务器
    • 解压缩
    • 建立软链接
    • 进入配置文件目录
    • 备份并编辑配置文件
    • 创建需要的目录
    • 配置每台服务器的`myid`文件
    • 启动Zookeeper(bash形式)
    • 启动Zookeeper(service形式)
      • 配置说明
      • 使用步骤
    • 查看服务是否启动成功

全是干货

部署三台zookeeper集群

安装Java环境

sudo yum update
sudo yum install java-1.8.0-openjdk-devel
java -version

准备zookeeper包

apache-zookeeper-3.5.10-bin.tar.gz

上传到服务器

解压缩

tar -zxvf apache-zookeeper-3.5.10-bin.tar.gz 

建立软链接

ln -s /opt/apache-zookeeper-3.5.10-bin /opt/zookeeper

进入配置文件目录

cd /opt/zookeeper/conf

备份并编辑配置文件

cp zoo_sample.cfg zoo.cfg
vim zoo.cfg
内容:(注意粘贴的时候检查一下完整性,修改一下自己的ip)
tickTime=2000
initLimit=10
syncLimit=5
dataDir=/opt/data/zookeeper
dataLogDir=/opt/logs/zookeeper
clientPort=2181
server.1=ip1:2188:3188
server.2==ip2:2188:3188
server.3==ip3:2188:3188
4lw.commands.whitelist=*

tickTime: Zookeeper的基本时间单位,单位为毫秒。

initLimit: Follower节点在启动并同步数据时,Leader允许的最长时间(tickTime的倍数)。

syncLimit: Leader允许Follower节点之间消息同步的最大延迟(tickTime的倍数)。

dataDir: 存放快照文件的目录。

dataLogDir: 存放事务日志的目录。

clientPort: 客户端连接Zookeeper的端口。

server.X: 定义集群中的每个服务器。格式为server.id=host:port:electPort,其中id是服务器的唯一标识,port是Follower连接Leader的端口,electPort是进行Leader选举的端口。

4lw.commands.whitelist: 允许的四字母命令。

创建需要的目录

mkdir -p /opt/data/zookeeper/
mkdir -p /opt/logs/zookeeper/

配置每台服务器的myid文件

echo 1 > /opt/data/zookeeper/myid  # 在ip1上
echo 2 > /opt/data/zookeeper/myid  # 在ip2上
echo 3 > /opt/data/zookeeper/myid  # 在ip3上

启动Zookeeper(bash形式)

在每台服务器上,进入Zookeeper的bin目录,并启动Zookeeper服务:

cd /opt/zookeeper/bin
./zkServer.sh start

启动Zookeeper(service形式)

进入到 /etc/systemd/system目录

cd /etc/systemd/system/

创建zookeeper.service并输入以下内容

[Unit]
Requires=network.target remote-fs.target
After=network.target remote-fs.target
[Service]
Type=forking
User=zookeeper
Group=zookeeper
Environment=ZOO_LOG_DIR=/opt/logs/zookeeper/
PIDFile=/opt/data/zookeeper/zookeeper_server.pid
ExecStartPre=/usr/bin/rm -f /opt/data/zookeeper/zookeeper_server.pid
ExecStart=/bin/sh -c '/opt/zookeeper/bin/zkServer.sh start'
ExecStop=/bin/sh -c '/opt/zookeeper/bin/zkServer.sh stop'
ExecReload=/bin/sh -c '/opt/zookeeper/bin/zkServer.sh restart'
Restart=on-abnormal
[Install]
WantedBy=multi-user.target

配置说明

  • [Unit]:定义服务的依赖和启动顺序。
    • Requires=network.target remote-fs.target:表示服务启动需要网络和远程文件系统。
    • After=network.target remote-fs.target:确保网络和远程文件系统在服务启动之前已经启动。
  • [Service]:定义服务的启动、停止和重启行为。
    • Type=forking:表示服务在启动时会创建一个新的进程。
    • User=zookeeperGroup=zookeeper:指定运行服务的用户和组。
    • Environment="ZOO_LOG_DIR=/opt/logs/zookeeper/":设置环境变量。
    • PIDFile=/opt/data/zookeeper/zookeeper_server.pid:指定PID文件的位置。
    • ExecStartPre=/usr/bin/rm -f /opt/data/zookeeper/zookeeper_server.pid:在启动之前删除旧的PID文件。
    • ExecStart=/opt/zookeeper/bin/zkServer.sh start /opt/zookeeper/conf/zoo.cfg:启动Zookeeper服务。
    • ExecStop=/opt/zookeeper/bin/zkServer.sh stop:停止Zookeeper服务。
    • ExecReload=/opt/zookeeper/bin/zkServer.sh restart:重启Zookeeper服务。
    • Restart=on-abnormal:在异常情况下重启服务。
    • LimitNOFILE=4096:增加文件描述符限制。
  • [Install]:定义服务的安装行为。
    • WantedBy=multi-user.target:表示服务在多用户系统目标(即系统正常启动后的状态)下可用。

使用步骤

  1. 创建用户和组: 确保存在运行Zookeeper服务的用户和组:

    sudo useradd -r -m -d /opt/zookeeper -s /sbin/nologin zookeeper
    
  2. 设置权限: 确保Zookeeper安装目录和数据目录的权限正确:

    sudo chown -R zookeeper:zookeeper /opt/data/zookeeper
    sudo chown -R zookeeper:zookeeper /opt/logs/zookeeper
    sudo chmod -R 755 /opt/data/zookeeper
    sudo chmod -R 755 /opt/logs/zookeeper
    
  3. 创建和启用服务: 将上面的服务单元文件内容保存到 /etc/systemd/system/zookeeper.service,然后运行以下命令重新加载systemd守护进程,并启动Zookeeper服务:

    sudo systemctl daemon-reload
    sudo systemctl enable zookeeper
    sudo systemctl start zookeeper
    
  4. 检查服务状态: 查看Zookeeper服务状态以确保其正常运行:

    sudo systemctl status zookeeper
    

通过上述配置,你可以通过systemctl命令来管理Zookeeper服务,例如启动、停止和重启。这确保了服务的统一管理和自动重启,增强了系统的稳定性和可维护性。

查看服务是否启动成功

ps -ef|grep zookeeper

在这里插入图片描述

这篇关于《日均70亿请求项目实战》之部署三台zookeeper集群的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1038010

相关文章

Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)

《Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)》文章介绍了如何使用dhtmlx-gantt组件来实现公司的甘特图需求,并提供了一个简单的Vue组件示例,文章还分享了一... 目录一、首先 npm 安装插件二、创建一个vue组件三、业务页面内 引用自定义组件:四、dhtmlx

Python与DeepSeek的深度融合实战

《Python与DeepSeek的深度融合实战》Python作为最受欢迎的编程语言之一,以其简洁易读的语法、丰富的库和广泛的应用场景,成为了无数开发者的首选,而DeepSeek,作为人工智能领域的新星... 目录一、python与DeepSeek的结合优势二、模型训练1. 数据准备2. 模型架构与参数设置3

Docker部署Jenkins持续集成(CI)工具的实现

《Docker部署Jenkins持续集成(CI)工具的实现》Jenkins是一个流行的开源自动化工具,广泛应用于持续集成(CI)和持续交付(CD)的环境中,本文介绍了使用Docker部署Jenkins... 目录前言一、准备工作二、设置变量和目录结构三、配置 docker 权限和网络四、启动 Jenkins

SpringBoot项目注入 traceId 追踪整个请求的日志链路(过程详解)

《SpringBoot项目注入traceId追踪整个请求的日志链路(过程详解)》本文介绍了如何在单体SpringBoot项目中通过手动实现过滤器或拦截器来注入traceId,以追踪整个请求的日志链... SpringBoot项目注入 traceId 来追踪整个请求的日志链路,有了 traceId, 我们在排

Java实战之利用POI生成Excel图表

《Java实战之利用POI生成Excel图表》ApachePOI是Java生态中处理Office文档的核心工具,这篇文章主要为大家详细介绍了如何在Excel中创建折线图,柱状图,饼图等常见图表,需要的... 目录一、环境配置与依赖管理二、数据源准备与工作表构建三、图表生成核心步骤1. 折线图(Line Ch

Java使用Tesseract-OCR实战教程

《Java使用Tesseract-OCR实战教程》本文介绍了如何在Java中使用Tesseract-OCR进行文本提取,包括Tesseract-OCR的安装、中文训练库的配置、依赖库的引入以及具体的代... 目录Java使用Tesseract-OCRTesseract-OCR安装配置中文训练库引入依赖代码实

SpringBoot中整合RabbitMQ(测试+部署上线最新完整)的过程

《SpringBoot中整合RabbitMQ(测试+部署上线最新完整)的过程》本文详细介绍了如何在虚拟机和宝塔面板中安装RabbitMQ,并使用Java代码实现消息的发送和接收,通过异步通讯,可以优化... 目录一、RabbitMQ安装二、启动RabbitMQ三、javascript编写Java代码1、引入

ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法

《ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法》本文介绍了Elasticsearch的基本概念,包括文档和字段、索引和映射,还详细描述了如何通过Docker... 目录1、ElasticSearch概念2、ElasticSearch、Kibana和IK分词器部署

部署Vue项目到服务器后404错误的原因及解决方案

《部署Vue项目到服务器后404错误的原因及解决方案》文章介绍了Vue项目部署步骤以及404错误的解决方案,部署步骤包括构建项目、上传文件、配置Web服务器、重启Nginx和访问域名,404错误通常是... 目录一、vue项目部署步骤二、404错误原因及解决方案错误场景原因分析解决方案一、Vue项目部署步骤

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2