Centos7使用docker搭建redis集群
前置准备:
Centos7安装docker就不多说了…
- 本次目的是搭建3主3从(当然你也可以按需扩展)
- 准备三台服务器,假定IP分别为:192.168.75.128、192.168.75.129、192.168.75.130
- 安装 redis:
#拉取redis
docker pull redis:5.0.2
#创建容器并运行
docker run --name redis -p 6379:6379 -d redis:5.0.2
1、准备docker-compose.yml文件
注意:最好在服务器上找个专门的文件夹存放这些yml文件,免得后面找不到了
1.1 服务器A【192.168.75.128】
# 文件名: docker-compose.yml(部署在每台服务器上)
version: '3.3'services:# 服务器 192.168.75.128 配置redis-master1:image: redis:5.0.2command: redis-server --port 7001 --cluster-enabled yes --cluster-config-file /data/nodes.conf --appendonly yes --bind 0.0.0.0 --cluster-announce-ip 192.168.75.128ports:- "7001:7001"- "17001:17001"volumes:- ./data/node1:/datanetworks:- redis-clusterredis-slave1:image: redis:5.0.2command: redis-server --port 7002 --cluster-enabled yes --cluster-config-file /data/nodes.conf --appendonly yes --bind 0.0.0.0 --cluster-announce-ip 192.168.75.128ports:- "7002:7002"- "17002:17002"volumes:- ./data/node2:/datanetworks:- redis-cluster# 定义 redis-cluster 网络
networks:redis-cluster:driver: overlay # 单机部署使用 bridge,多机部署可改用 overlayattachable: true # 允许独立容器加入网络# 服务器 192.168.75.129 和 192.168.75.130 的配置类似,需替换 IP 和数据目录:
# 192.168.75.129: redis-master2 (7003), redis-slave2 (7004)
# 192.168.75.130: redis-master3 (7005), redis-slave3 (7006)
1.2 服务B【192.168.75.129】
# 文件名: docker-compose.yml(部署在每台服务器上)
version: '3.3'services:# 服务器 192.168.75.129 配置redis-master1:image: redis:5.0.2command: redis-server --port 7003 --cluster-enabled yes --cluster-config-file /data/nodes.conf --appendonly yes --bind 0.0.0.0 --cluster-announce-ip 192.168.75.129ports:- "7003:7003"- "17003:17003"volumes:- ./data/node3:/datanetworks:- redis-clusterredis-slave1:image: redis:5.0.2command: redis-server --port 7004 --cluster-enabled yes --cluster-config-file /data/nodes.conf --appendonly yes --bind 0.0.0.0 --cluster-announce-ip 192.168.75.129ports:- "7004:7004"- "17004:17004"volumes:- ./data/node4:/datanetworks:- redis-cluster# 定义 redis-cluster 网络
networks:redis-cluster:driver: overlay # 单机部署使用 bridge,多机部署可改用 overlayattachable: true # 允许独立容器加入网络# 服务器 192.168.75.128 和 192.168.75.130 的配置类似,需替换 IP 和数据目录:
# 192.168.75.128: redis-master1 (7001), redis-slave1 (7002)
# 192.168.75.130: redis-master3 (7005), redis-slave3 (7006)
1.3 服务器C【192.168.75.130】
# 文件名: docker-compose.yml(部署在每台服务器上)
version: '3.3'services:# 服务器 192.168.75.130 配置redis-master1:image: redis:5.0.2command: redis-server --port 7005 --cluster-enabled yes --cluster-config-file /data/nodes.conf --appendonly yes --bind 0.0.0.0 --cluster-announce-ip 192.168.75.130ports:- "7005:7005"- "17005:17005"volumes:- ./data/node5:/datanetworks:- redis-clusterredis-slave1:image: redis:5.0command: redis-server --port 7006 --cluster-enabled yes --cluster-config-file /data/nodes.conf --appendonly yes --bind 0.0.0.0 --cluster-announce-ip 192.168.75.130ports:- "7006:7006"- "17006:17006"volumes:- ./data/node6:/datanetworks:- redis-cluster# 定义 redis-cluster 网络
networks:redis-cluster:driver: overlay # 单机部署使用 bridge,多机部署可改用 overlayattachable: true # 允许独立容器加入网络# 服务器 192.168.75.128 和 192.168.75.129 的配置类似,需替换 IP 和数据目录:
# 192.168.75.128: redis-master1 (7001), redis-slave1 (7002)
# 192.168.75.129: redis-master2 (7003), redis-slave2 (7004)
2、执行docker-compose.yml文件
2.1 执行命令:
执行前先要使用安装下docker的编排组件:yum install docker-compose
- 执行这个
yum install docker-compose命令可能会提示没这个包,就需要执行如下命令:
更新yum源
sudo yum -y install epel-release
然后可以直接安装
yum install docker-compose
-
然后在yml文件所在目录执行如下命令:
docker-compose up -d -
然后报错:
ERROR: This node is not a swarm manager. Use "docker swarm init" or "docker swarm join" to connect this node to swarm and try again. -
这个提示需要使用
docker swarm init命令搭建 Redis 集群,核心原因在于 Docker Swarm 提供了容器编排能力,而 Redis 集群的分布式特性需要依赖 Swarm 的底层架构实现多节点协同和管理。docker swarm init会创建 Swarm 集群的管理节点(Manager),负责调度服务、维护集群状态,并为后续加入的 Worker 节点提供通信基础,同时也提供了动态扩缩容能力等能力。
2.2 初始化 Swarm 集群
若当前节点需作为 管理节点(Manager):
# 指定本机 IP 初始化 Swarm:ml-citation{ref="4,6" data="citationList"}
docker swarm init --advertise-addr <本机IP>
-
关键参数:–advertise-addr 声明管理节点的通信地址,确保其他节点可访问36。
-
成功标志:输出包含 Swarm initialized 及 Worker/Manager 加入命令
-
有如下提示就表示加入成功:

-
继续执行命令:
docker-compose up -d

执行Redis集群启动命令:
注意:执行前需要安装redis-cli工具,自行根据所需redis-lic版本安装
# --cluster-replicas 1:为每个主节点分配 1 个从节点
# 自动分配规则:前 3 个 IP 为主节点,后 3 个 IP 为从节点
redis-cli --cluster create 192.168.75.128:7001 192.168.75.129:7003 192.168.75.130:7005 192.168.75.128:7002 192.168.75.129:7004 192.168.75.130:7006 --cluster-replicas 1
- 有如下信息表示集群启动成功:

- 再验证下:
redis-cli -h 192.168.75.128 -p 7001 cluster nodes

爱在深秋~ peace !
相关文章:
Centos7使用docker搭建redis集群
前置准备: Centos7安装docker就不多说了… 本次目的是搭建3主3从(当然你也可以按需扩展)准备三台服务器,假定IP分别为:192.168.75.128、192.168.75.129、192.168.75.130安装 redis: #拉取redis docker p…...
蓝桥杯备赛-二分-跳石头
问题描述 一年一度的"跳石头"比赛又要开始了! 这项比赛将在一条笔直的河道中进行,河道中分布着一些巨大岩石。组委会已经选择好了两块岩石作为比赛起点和终点。在起点和终点之间,有 NN 块岩石(不含起点和终点的岩石&a…...
【09】单片机编程核心技巧:变量赋值,从定义到存储的底层逻辑
【09】单片机编程核心技巧:变量赋值,从定义到存储的底层逻辑 🌟 核心概念 单片机变量的定义与赋值是程序设计的基础,其本质是通过 RAM(随机存储器) 和 ROM(只读存储器) 的协作实现…...
数字孪生像魔镜,映照出无限可能的未来
在当今科技飞速发展的时代,数字孪生作为一项极具潜力的前沿技术,正逐渐崭露头角,成为众多领域关注的焦点。它犹如一面神奇的魔镜,以数字化的方式精准映照出现实世界中的各种实体与系统,为我们开启了一扇通往无限可能未…...
加密算法逆向与HOOK技术实战
1. 密码学基础与逆向特征识别 1.1 算法分类与模式特征 常见算法指纹库: # 算法特征识别字典 CRYPTO_SIGNATURES { "AES": { "init": ["AES/ECB", "AES/CBC", "AES/GCM"], "key_len": [128, 2…...
前端知识点---原型-原型链(javascript)
文章目录 原型原型链:实际应用面试题回答 原型 原型:每个函数都有prototype属性 称之为原型 因为这个属性的值是个对象,也称为原型对象 只有函数才有prototype属性 作用: 1.存放一些属性和方法 2.在Javascript中实现继承 const arr new Array(1, 2, 3, 4) con…...
数据类设计_图片类设计之6_混合图形类设计(前端架构)
前言 学的东西多了,要想办法用出来.C和C是偏向底层的语言,直接与数据打交道.尝试做一些和数据方面相关的内容 引入 接续上一篇,讨论混合图形类设计 方法论-现在能做什么 这段属于聊天内容---有句话是这么说的:不要只埋头拉车,还要抬头看路。写代码也是…...
2024年12月CCF-GESP编程能力等级认证C++编程一级真题解析
一级真题的难度: CCF-GESP编程能力等级认证C++编程一级真题的难度适中。这些真题主要考察的是C++编程的基础知识、基本语法以及简单的算法逻辑。从搜索结果中可以看到,真题内容包括了选择题、编程题等题型,涉及的内容如C++表达式的计算、基本输入输出语句的理解…...
尤瓦尔·诺亚·赫拉利(Yuval Noah Harari)作品和思想深度报告
尤瓦尔诺亚赫拉利(Yuval Noah Harari)作品和思想深度报告 引言 尤瓦尔诺亚赫拉利(Yuval Noah Harari)是当今最具影响力的公众知识分子之一 ynharari.com 。作为一名历史学家和哲学家,他以宏大的视角和清晰生动的语言…...
JConsole:JDK性能监控利器之JConsole的使用说明与案例实践
🪁🍁 希望本文能给您带来帮助,如果有任何问题,欢迎批评指正!🐅🐾🍁🐥 文章目录 一、背景二、JConsole的启动与连接2.1 JConsole的启动2.2 进程连接2.2.1 本地进程连接2.2…...
Neural Architecture Search for Transformers:A Survey
摘要 基于 Transformer 的深度神经网络架构因其在自然语言处理 (NLP) 和计算机视觉 (CV) 领域的各种应用中的有效性而引起了极大的兴趣。这些模型是多种语言任务(例如情绪分析和文本摘要)的实际选择,取代了长短期记忆 (LSTM) 模型。视觉 Tr…...
Browser Copilot 开源浏览器扩展,使用现有或定制的 AI 助手来完成日常 Web 应用程序任务。
一、软件介绍 文末提供源码和开源扩展程序下载 Browser Copilot 是一个开源浏览器扩展,允许您使用现有或定制的 AI 助手来帮助您完成日常 Web 应用程序任务。 目标是提供多功能的 UI 和简单的框架,以实现和使用越来越多的 copilots(AI 助手&…...
基于PSO粒子群优化的XGBoost时间序列预测算法matlab仿真
目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 4.1 XGBoost算法原理 4.2 XGBoost优化 5.算法完整程序工程 1.算法运行效果图预览 (完整程序运行后无水印) 2.算法运行软件版本 matlab2024b 3.部分核心程序 (完整版代码包含…...
股票查询系统
使用sql创建一个database,名称为:stock,在stock中创建一个表,名称为:stocks, 表中的各个字段为: stock_code 最大6位整数数字,必须填写 stock_name, 最大20个汉字,必须填…...
aws(学习笔记第三十三课) 深入使用cdk 练习aws athena
文章目录 aws(学习笔记第三十三课) 深入使用cdk学习内容:1. 使用aws athena1.1 什么是aws athena1.2 什么是aws glue1.2 为什么aws athena和aws glue一起使用 2. 开始练习aws athena2.1 代码链接2.2 整体架构2.3 代码解析2.3.1 创建测试数据的S3 bucket2.3.2 创建保…...
基于RAGFlow本地部署DeepSpeek-R1大模型与知识库:从配置到应用的全流程解析
作者:后端小肥肠 🍊 有疑问可私信或评论区联系我。 🥑 创作不易未经允许严禁转载。 姊妹篇: DeepSpeek服务器繁忙?这几种替代方案帮你流畅使用!(附本地部署教程)-CSDN博客 10分钟上手…...
ESP-IDF中FreeRTOS的三种任务调度算法
本文内容参考: STM32F103移植FreeRTOS必须搞明白的系列知识---2(FreeRTOS任务优先级)_freertos最多支持多少个任务-CSDN博客 浅析FreeRTOS任务调度器的三种调度算法和应用-电子发烧友网 特此致谢! FreeRTOS中的任务调度算法 FreeRTOS支持多种任务调度算法,可通过配置来…...
SpringBoot 集成logback日志链路追踪
项目场景 有时候一个业务调用链场景,很长,调了各种各样的方法,看日志的时候,各个接口的日志穿插,确实让人头大。 为了解决这个痛点,就使用了 TraceId,根据 TraceId 关键字进入服务器查询日志中…...
【Python办公】Excel通用匹配工具(双表互匹)
目录 专栏导读1、背景介绍2、库的安装3、核心代码4、完整代码总结专栏导读 🌸 欢迎来到Python办公自动化专栏—Python处理办公问题,解放您的双手 🏳️🌈 博客主页:请点击——> 一晌小贪欢的博客主页求关注 👍 该系列文章专栏:请点击——>Python办公自动化专…...
【JAVA】七、基础知识“if+switch+循环结构”详细讲解~简单易懂!
目录 7、逻辑控制 7.1 分支结构 7.1.1 if 语句 语法格式1 语法格式2 语法格式3 7.1.2 switch语句 基本语法 执行流程 7.2 循环结构 7.2.1 while循环 语法格式 7.2.2 Break 7.2.3 Continue 7.2.4 for循环 语法格式 执行过程 7.2.5 do while循环 语法格式 7.3 …...
【C++】每日一练(轮转数组)
本篇博客给大家带来的是用C语言来解答轮转数组! 🐟🐟文章专栏:每日一练 🚀🚀若有问题评论区下讨论,我会及时回答 ❤❤欢迎大家点赞、收藏、分享! 今日思想:不服输的少年啊…...
Java 反射机制学习
Java 反射机制详解 Java 反射(Reflection)是 Java 语言的一种强大特性,允许程序在运行时动态地获取类的信息并操作类或对象的属性、方法和构造器。反射机制打破了 Java 的封装性,但也提供了极大的灵活性,常用于框架开…...
GetCurrentTime
在实际编程中难免要获取当前时间并且进行格式化,本文给出了多种 GetCurrentTime() 方法以供选择。 C语言下使用strftime C 语言中可以使用 <time.h> 中的函数来获取和格式化时间 #include <stdio.h> #include <time.h>char* getCurrentTime() …...
计算机的结构形式
微机的机构形式 台式个人微机 最开始的微机(计算机)都是台式的,到目前为止仍是个人微机的主要形式。台式机按照电脑机箱的放置形式,分为卧式和立式两种。台式机需要放在桌面上或者留有专门放置机箱位置,他的主机、键…...
SSL/TLS 1.2过程:Client端如何验证服务端证书?
快速回顾非对称加密和对称加密 首先快速说一下非对称加密和对称加密。非对称加密,就是有一个公钥和私钥(成对存在)。 公钥对一段文本A加密得到文本B,只有对应的私钥能对B解密得到A。 私钥对一段文本C加密得到文本D,只有对应的公钥能对D解密得…...
Python(学习一)
做网站有成熟的框架像FLASK、DJANGO、TORNADO,写爬虫有好用到哭的REQUESTS,还有强大到没盆友的SCRAPY 随着NUMPY、SCIPY、MATLOTLIB等众多第三方模块的开发和完善,不仅支持py支持各种数学运算,还可以绘制高质量的2D和3D图像&…...
Java中类和对象
类和对象 面向对象的认识类的定义和使用1 类的定义2 类的创建3 类的实例化 构造方法1 构造方法的概念2 构造方法的注意事项 this关键字 面向对象的认识 前言 何为面向对象何为面向过程呢?,C语言是最经典的面向过程的语言,但是C语言虽然可以解决一定的问…...
文本组件+Image组件+图集
Canvas部分知识补充 元素渲染顺序 以Hierarchy参考 下方物体在上方物体前显示 子物体在父物体前显示 下方物体永远在前显示,无论上方的层次结构 资源导入 绝对路径:C:\Windows\Fonts下的许多字体可以用做UIText的字体资源 图片导入: 1.图…...
Audacity 技术浅析(一)
Audacity 是一个开源的音频编辑工具,虽然它主要用于音频编辑和处理,但也可以通过一些插件和功能实现基本的音频生成功能。 1. Audacity 的音频生成基础 Audacity 的音频生成主要依赖于其内置的生成器、效果器以及 Nyquist 编程语言。这些工具允许用户创…...
PyCharm 2019.1.3使用python3.9创建虚拟环境setuptools-40.8.0报错处理
目录 前置: 一劳永逸方法(缺最后一步,没有成行) step one: 下载高版本的pip、setuptools、virtualenv的tar.gz包 step two: 进入PyCharm安装目录的 helpers 目录下 step three: 下载并安装grep和sed命令,然后执行 …...
