linux使用docker实现redis主从复制和哨兵模式
目录
1. 拉取redis镜像
2.使用可视化redis工具
3. 设置从redis
4.设置哨兵模式
5. 使用docker-compose快速创建
1. 拉取redis镜像
docker pull redis
默认拉取最新的镜像。
然后pull结束后使用docker images检查镜像:
![]()
然后docker run创建container容器
首先创建主redis服务
先使用如下命令创建redis.conf文件和data文件夹用于存放docker container中的volume:
mkdir -p /home/test_redis/redis_master_1/conf
mkdir -p /home/test_redis/redis_master_1/data
touch /home/test_redis/redis_master_1/conf/redis.conf
然后vim /home/test_redis/redis_master_1/conf/redis.conf 编辑配置文件
主redis其实不需要配置,默认就好,所以redis.conf为空就可以
然后创建container容器:
docker run -d -p 6379:6379 --restart unless-stopped \
-v /home/test_redis/redis_master_1/data:/data \
-v /home/test_redis/redis_master_1/conf/redis.conf:/etc/redis/redis.conf \
--name redis_master_1 \
redis \
redis-server
然后复制到命令行运行
运行成功后:

2.使用可视化redis工具
使用redisinsight工具,官网:RedisInsight - The Best Redis GUI
然后下载安装:

这里下载需要填写各种信息。提供下载好的windows版本:
https://wwf.lanzouo.com/ihBUC1utxjmf
密码:hehb
我这里使用windows版本远程连接


填写ip和端口号

连接后是空,添加一个key

也可使用cli命令行工具

3. 设置从redis
这里另外创建一个redis容器
不过redis.conf需要修改。
首先创建文件夹和文件,这里直接复制
cd /home/test_redis/
mkdir -p redis_slave_1/data
mkdir -p redis_slave_1/conf
touch redis_slave_1/conf/redis.conf
然后编辑redis.conf,输入如下内容:
port 6380replicaof <ip地址> 6379
然后创建容器:
docker run -d -p 6380:6380 --restart unless-stopped \
-v /home/test_redis/redis_slave_1/data:/data \
-v /home/test_redis/redis_slave_1/conf/redis.conf:/etc/redis/redis.conf \
--name redis_slave_1 \
redis \
redis-server /etc/redis/redis.conf
然后用redisinsight连接6380端口
连接成功后在cli命令行键入 info replication命令:

说明已经连接上了。
查看一下Key:

成功复制了主redis的key。
然后测试在从redis创建key

报错,因为从redis只能复制主redis,即不能写。
尝试在主redis设置key:

从redis:

主从复制设置成功
然后再添加一个从redis
cd /home/test_redis/
cp -r redis_slave_1 reids_slave_2
rm redis_slave_2/data/*
vim redis_slave_2/conf/redis.conf
输入如下内容:
port 6381replicaof 121.37.188.69 6379
就改了一下端口
然后创建容器:
docker run -d -p 6381:6381 --restart unless-stopped \
-v /home/test_redis/redis_slave_2/data:/data \
-v /home/test_redis/redis_slave_2/conf/redis.conf:/etc/redis/redis.conf \
--name redis_slave_2 \
redis \
redis-server /etc/redis/redis.conf
在主redis的redisinsight窗口的cli命令行输入info replication

现在已经有两个从redis了。
检查一下新的从redis:

数据也复制过来了。
4.设置哨兵模式
这里还是使用之前pull的redis镜像,只不过更改了配置文件: sentinel.conf,redis-server运行时也是运行sentinel.conf文件。
然后运行如下命令:
cd /home/test_redis
cp -r redis_master_1 redis_sentinel_1
rm redis_sentinel_1/data/*
rm redis_sentinel_1/conf/*
touch redis_sentinel_1/conf/sentinel.conf
vim redis_sentinel_1/conf/sentinel.conf
输入如下内容:
sentinel monitor mymaster 121.37.188.69 6379 1
表示只需一个哨兵即可开启哨兵模式。
然后创建容器:
docker run -d --restart unless-stopped \
-v /home/test_redis/redis_sentinel_1/data:/data \
-v /home/test_redis/redis_sentinel_1/conf/sentinel.conf:/etc/redis/sentinel.conf \
--name redis_sentinel_1 \
redis \
redis-sentinel /etc/redis/sentinel.conf
进入docker内部检查:

已经配置成功。
尝试关闭主redis模拟主redis故障
这里世界docker stop 停止主redis
docker stop redis_master_1
6380 redis

6381从redis

可以看到6380变为了主redis, 6381还是从redis
尝试设置6380的key:

6381:

6381成功更新
这时重启6379:
docker start redis_master_1

6379变为6380的从redis了,并且数据也复制了:

哨兵模式设置成功。
5. 使用docker-compose快速创建
前面总公设置了4个服务,使用docker-compose可以一次性部署:
cd /home
cp -r test_redis test_redis_2
cd /home/test_resis_2
rm */data/*
创建docker-compose.yml文件:
touch docker-compose.yml
输入如下内容:
version: '3'services:redis_master_1:ports:- "6379:6379"image: "redis"restart: unless-stoppedvolumes:- /home/test_redis_2/redis_master_1/data:/data- /home/test_redis_2/redis_master_1/conf/redis.conf:/etc/redis/redis.confcommand: redis-server /etc/redis/redis.confredis_slave_1:ports:- "6380:6380"image: "redis"restart: unless-stoppedvolumes:- /home/test_redis_2/redis_slave_1/data:/data- /home/test_redis_2/redis_slave_1/conf/redis.conf:/etc/redis/redis.confcommand: redis-server /etc/redis/redis.confredis_slave_2:ports:- "6381:6381"image: "redis"restart: unless-stoppedvolumes:- /home/test_redis_2/redis_slave_2/data:/data- /home/test_redis_2/redis_slave_2/conf/redis.conf:/etc/redis/redis.confcommand: redis-server /etc/redis/redis.confredis_sentinel_1:image: "redis"restart: unless-stoppedvolumes:- /home/test_redis_2/redis_sentinel_1/data:/data- /home/test_redis_2/redis_sentinel_1/conf/sentinel.conf:/etc/redis/sentinel.confcommand: redis-sentinel /etc/redis/sentinel.conf
结果:

测试:
测试可行,这里就不放图了。
使用docker-compose主要是方便部署。

相关文章:
linux使用docker实现redis主从复制和哨兵模式
目录 1. 拉取redis镜像 2.使用可视化redis工具 3. 设置从redis 4.设置哨兵模式 5. 使用docker-compose快速创建 1. 拉取redis镜像 docker pull redis 默认拉取最新的镜像。 然后pull结束后使用docker images检查镜像: 然后docker run创建container容器 首先…...
新版chrome 解决在http协议下无法调用摄像头和麦克风的问题(不安全)
解决办法:亲测可行 chrome浏览器地址栏中输入chrome://flags/#unsafely-treat-insecure-origin-as-secure,回车,如下图,将该选项置为Enabled, edge浏览器打开:edge://flags/#unsafely-treat-insecure-orig…...
机器学习入门项目二(逻辑回归)
如果输入数据长度为2,上一章的方程就无法满足需求了,需要修改方程: z w 1 x w 2 y b zw_1xw_2yb zw1xw2yb 数据产生器: import matplotlib.pyplot as plt import numpy as npclass DataGenerator2Input:"""…...
C++类引用的好处
简化代码:引用可以简化代码,使其更加易读和易懂。通过使用引用,可以避免在函数参数中复制大型对象,从而提高代码的效率和性能。 传递大型对象的效率高:使用引用作为函数参数传递大型对象时,不需要进行对象…...
从零自制docker-9-【管道实现run进程和init进程传参】
文章目录 命令行中输入参数长度过长匿名管道从父进程到子进程传参[]*os.File{}os.NewFile和io.ReadAllexe.LookPathsyscall.Execstrings.Split(msgStr, " ")/bin/ls: cannot access : No such file or directory代码 命令行中输入参数长度过长 用户输入参数过长或包…...
全量知识系统 程序详细设计 之 三种“活物” 之1(QA百度搜索 )
Q1. 今天聊聊 全知系统中 三种“活物”。先从他们的一个简单描述开始: 自主:计算机“集群”的“沉”与“浮”; 自然:AI “众生”的“世”和“界” ;自由:人类 “公民”的“宇”或“宙”。 全知系统中的三…...
QT 线程之movetothread
上文列举了qt中线程的几种方法,其中2种方法最为常见。 这两种方法都少不了QThread类,前者继承于QThread类,后者复合QThread类。 本文以实例的方式描述了movetothread()这种线程的方法,将QObject的子类移动…...
如何处理ubuntu22.04LTS安装过程中出现“Daemons using outdated libraries”提示
Ubuntu 22.04 LTS 中使用命令行升级软件或安装任何新软件时,您可能收到“Daemons using outdated libraries”,“Which services should be restarted?”的提示,提示下面列出备选的重启服务,如下。 使用以下命令,能够…...
跟TED演讲学英文:The inside story of ChatGPT‘s astonishing potential by Greg Brockman
The inside story of ChatGPT’s astonishing potential Link: https://www.ted.com/talks/greg_brockman_the_inside_story_of_chatgpt_s_astonishing_potential Speaker: Greg Brockman Date:April 2023 文章目录 The inside story of ChatGPTs astonishing potentialIntro…...
mybatis05:复杂查询:(多对一,一对多)
mybatis05:复杂查询:(多对一,一对多) 文章目录 mybatis05:复杂查询:(多对一,一对多)前言:多对一 : 关联 : 使用associatio…...
微电网优化:基于肝癌算法(Liver Cancer algorithm, LCA)的微电网优化(提供MATLAB代码)
一、微电网优化模型 微电网是一个相对独立的本地化电力单元,用户现场的分布式发电可以支持用电需求。为此,您的微电网将接入、监控、预测和控制您本地的分布式能源系统,同时强化供电系统的弹性,保障您的用电更经济。您可以在连接…...
VUE_H5页面跳转第三方地图导航,兼容微信浏览器
当前项目是uniapp项目,若不是需要替换uni.showActionSheet选择api onMap(address , organName , longitude 0, latitude 0){var ua navigator.userAgent.toLowerCase();var isWeixin ua.indexOf(micromessenger) ! -1;if(isWeixin) {const mapUrl_tx "…...
智慧安全运营:智能化运维,确保服务无忧
智慧安全运营:智能化运维,确保服务无忧 中国联通新一代全球智云数据中心采用先进的智能化运维管理系统,实现对数据中心设施、IT设备、能源消耗、环境参数等全方位、实时监控。通过物联网技术、人工智能算法以及大数据分析,运维团…...
R-tree总结
引言: 在处理空间数据和地理信息系统(GIS)中,高效的空间索引机制对于提升查询性能至关重要。R-tree是一种流行的平衡树数据结构,专门用于索引多维信息,如二维的地理坐标或三维的物体位置。它以其灵活性、高…...
Python 与机器学习,在服务器使用过程中,常用的 Linux 命令包括哪些?
🍉 CSDN 叶庭云:https://yetingyun.blog.csdn.net/ 本博客旨在分享在实际开发过程中,开发者需要了解并熟练运用的 Linux 操作系统常用命令。Linux 作为一种操作系统,与 Windows 或 MacOS 并驾齐驱,尤其在服务器和开发环…...
js通过Object.defineProperty实现数据响应式
目录 数据响应式属性描述符propertyResponsive 依赖收集依赖队列寻找依赖 观察器 派发更新Observer完整代码关于数据响应式关于Object.defineProperty的限制 数据响应式 假设我们现在有这么一个页面 <!DOCTYPE html> <html lang"en"><head><m…...
docker最简单教程(使用dockerfile构建环境)
一 手里有的东西 安装好的docker+dockerfile 二 操作 只需要在你的dockerfile文件下执行命令 docker build -t="xianhu/centos:gitdir" . 将用户名、操作系统和tag进行修改就可以了,这就相当于在你本地安装了一个docker环境,然后执行 docker run -it xianhu/ce…...
Vue2 —— 学习(三)
目录 一、绑定 class 样式 (一)字符串写法 1.流程介绍 2.代码实现 (二)数组写法 1.流程介绍 2.代码实现 (三)对象写法 1.流程介绍 2.代码实现 二、绑定 style 样式(了解ÿ…...
Qt Creator 12.0.2 debug 无法查看变量的值 Expression too Complex
鼠标放在局部变量上提示“expression too complex”。 在调试窗口也看不到局部变量的值。 这应该是qt的一个bug,https://bugreports.qt.io/browse/QTCREATORBUG-24180 暂时解决方法: 如下图,需要右键项目然后执行"Clean"和&quo…...
LeetCode-Java:303、304区域检索(前缀和)
文章目录 题目303、区域和检索(数组不可变)304、二维区域和检索(矩阵不可变) 解①303,一维前缀和②304,二维前缀和 算法前缀和一维前缀和二维前缀和 题目 303、区域和检索(数组不可变ÿ…...
工程师幽默竞赛:从技术梗到团队文化的创意表达
1. 项目概述:一场工程师的幽默竞赛如果你在电子工程行业待过一段时间,大概率在《EE Times》这样的行业媒体上,见过那种线条简洁、寓意深刻的单格漫画。漫画本身往往描绘一个充满电子元件、示波器或一脸困惑的工程师的实验室场景,但…...
詹姆斯·韦伯望远镜:344个单点故障背后的航天工程极限挑战
1. 韦伯望远镜的“生死十日”:一场价值百亿美元的太空芭蕾作为一名在航天与深空探测领域摸爬滚打了十几年的工程师,我经历过无数次地面测试的紧张,也见证过发射倒计时的屏息瞬间。但像詹姆斯韦伯空间望远镜(JWST)这样&…...
复杂技术决策如何避免“竞选广告”陷阱?工程师必备的4项流程变革
1. 从一场“选举广告”引发的思考:工程师如何审视复杂系统设计午餐时看新闻,每个广告时段都被政治竞选广告塞满,内容无一例外都在攻击对手,却对自身主张闭口不谈。这场景让我这个在电子设计自动化(EDA)和半…...
2026年国民技术数字IC笔试试卷带答案
满分:100分 时间:90分钟 一、单选题(每题3分,共30分) 1. 在静态时序分析(STA)中,建立时间检查的公式为( ) A. Tclk + Tskew ≥ Tck-q + Tlogic + Tsetup B. Tclk - Tskew ≥ Tck-q + Tlogic + Tsetup C. Tclk ≥ Tck-q + Tlogic - Tsetup D. Tlogic ≥ Tsetup + Tho…...
基于ChatGPT与Telethon的Telegram频道智能评论机器人开发指南
1. 项目概述与核心价值 如果你在运营Telegram频道,或者需要管理多个社群,肯定遇到过这样的场景:频道里每天都有大量新消息,你想保持活跃度、引导讨论,但手动回复每一条消息不仅耗时耗力,还很难保证回复的质…...
风机技术演进与主动冷却系统优化实践
1. 风机技术演进与主动空气冷却系统优化作为一名在热管理领域工作多年的工程师,我见证了风机技术从简单的散热部件发展为精密的热管理系统的全过程。现代电子设备功率密度不断提升,从智能手机到数据中心服务器,散热设计已成为产品成败的关键因…...
收藏!小白程序员必看:从AI提效到重构产品,企业智能转型4阶段实战指南
本文深入探讨了企业如何拥抱智能时代,通过4个阶段实现AI落地。从提升内部效率开始,逐步激活沉睡数据,重构产品价值,最终形成深场景智能闭环。强调AI不应仅用于替代人工,更要关注为客户创造新价值、提升产品智能化&…...
Dify实战指南:从零构建大模型应用与智能体开发全流程
1. 项目概述:从零到一,构建你的大模型应用开发实战手册如果你对AI应用开发感兴趣,但又觉得从零开始搭建一个能用的智能体(Agent)或者知识库问答系统门槛太高,那么你很可能已经听说过Dify这个名字。作为一个…...
为Odoo ERP构建安全的AI数据访问层:基于权限治理的语义查询实践
1. 项目概述:为Odoo ERP构建一个受治理的AI数据访问层如果你正在使用Odoo管理企业业务,同时又希望让AI助手(比如Claude、Cursor)能够安全地查询销售数据、分析库存状况,而不是让它们直接面对你的生产数据库写SQL&#…...
如何快速掌握Blender精确建模:CAD_Sketcher完整实战指南
如何快速掌握Blender精确建模:CAD_Sketcher完整实战指南 【免费下载链接】CAD_Sketcher Constraint-based geometry sketcher for blender 项目地址: https://gitcode.com/gh_mirrors/ca/CAD_Sketcher 你是否曾经希望在Blender中创建精确的工程图纸ÿ…...
