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、区域和检索(数组不可变ÿ…...
模型timm/ViT-B-16-SigLIP简要介绍及其应用场景
目录一、timm/ViT-B-16-SigLIP 是什么模型二、模型结构(核心架构)1️⃣ 图像编码器2️⃣ 文本编码器3️⃣ 对齐训练三、为什么叫 ViT-B-16四、在 timm 中如何使用五、典型应用场景1️⃣ Zero-shot 图像分类2️⃣ 图文检索(Image-Text Retriev…...
符号回归的工程化实践:基于深度学习的物理定律自动发现与工业部署
1. 符号回归:当深度学习遇见物理定律发现 第一次接触符号回归时,我被它的"反套路"特性惊艳到了——大多数深度学习模型都在努力变得更复杂,而它却在追求用最简单的数学公式解释世界。三年前我在化工厂做反应釜监控项目时࿰…...
基于SpringBoot的租车系统毕设实战:从需求建模到高可用部署
最近在辅导学弟学妹做毕业设计,发现很多“基于SpringBoot的租车系统”项目,虽然功能列表很长,但仔细一看,架构松散,业务逻辑像面条代码,更别提应对真实场景下的并发问题了。今天,我就结合自己做…...
合肥高中英语一对一辅导2026指南,突破听说读写全面提升路径
合肥高中英语一对一辅导2026指南,突破听说读写全面提升路径据《2026年中国基础教育课外辅导行业白皮书》数据显示,2026年高中阶段英语学科辅导需求同比增长23%,其中超过65%的学生家长明确表示,传统大班教学已无法满足孩子个性化提…...
超越极限:YOLOv8融合Dynamic Head(统一尺度-空间-任务感知注意力)—— 原理详解、代码实现与性能验证
引言 在目标检测领域,YOLO系列模型凭借其出色的速度与精度平衡,始终占据着举足轻重的地位。YOLOv8作为Ultralytics团队的最新力作,在架构设计、训练策略和部署便捷性上均达到了新的高度。然而,随着应用场景的日益复杂,如何让模型在多尺度变化、空间遮挡、任务干扰等挑战下…...
# 数据仓库分层设计指南
从 0 搭建企业级数仓架构,ODS/DWD/DWS/ADS 分层详解📌 前言 为什么你的 SQL 越来越难维护? 为什么每次加需求都要改一堆表? 为什么数据口径对不上? 根本原因:没有分层设计! 这篇文章带你从零设计…...
5分钟玩转OpenClaw:nanobot镜像云端体验与本地调试对比
5分钟玩转OpenClaw:nanobot镜像云端体验与本地调试对比 1. 为什么需要对比云端与本地两种体验方式 作为一个长期折腾AI工具的开发者,我最近在测试OpenClaw时遇到了一个典型困境:是直接在本地电脑安装全套环境,还是先用云端沙盒快…...
GetQzonehistory完整指南:三步实现QQ空间历史说说一键备份
GetQzonehistory完整指南:三步实现QQ空间历史说说一键备份 【免费下载链接】GetQzonehistory 获取QQ空间发布的历史说说 项目地址: https://gitcode.com/GitHub_Trending/ge/GetQzonehistory GetQzonehistory是一款专为QQ空间用户设计的智能数据备份工具&…...
w3x2lni:魔兽地图跨版本转换的技术突破与实践指南
w3x2lni:魔兽地图跨版本转换的技术突破与实践指南 【免费下载链接】w3x2lni 魔兽地图格式转换工具 项目地址: https://gitcode.com/gh_mirrors/w3/w3x2lni 问题引入:版本壁垒下的魔兽地图开发困境 在魔兽争霸III的地图开发领域,版本迭…...
实测对比:openEuler三大桌面环境UKUI/DDE/XFCE安装体验与性能消耗
实测对比:openEuler三大桌面环境UKUI/DDE/XFCE安装体验与性能消耗 当技术决策者面对openEuler操作系统时,桌面环境的选择往往成为影响工作效率的关键因素。本文将基于openEuler 24.03 LTS环境,深度实测UKUI、DDE和XFCE三大主流桌面环境&…...
