docker安装Redis高可用(一主二从三哨兵)

本次教程使用docker swarm安装

准备三台机器

hostIP用途
node1192.168.31.130redis-master01,redis哨兵节点01
node2192.168.31.131redis-slave01, redis哨兵节点02
node3192.168.31.132redis-slave02 redis哨兵节点02

注意事项:
1:需要保证三台机器在一个网络或一个服务器安全组内(相互能ping通)
2: 为了演示需要将哨兵节点与redis节点安装在同一个机器,实际线上需要哨兵与redis分开部署以达到高可用性。

目录

    • 1:创建redis数据挂载卷
    • 2: 创建redis专用的网络
    • 3:下载/配置redis配置文件
    • 4:创建redis集群service
    • 5:配置主从关系
    • 6:创建redis哨兵数据挂载卷
    • 7:创建redis哨兵集群service

1:创建redis数据挂载卷

#node1机器上执行
docker volume create --name redis_cluster_data1
#node2机器上执行
docker volume create --name redis_cluster_data2
#node3机器上执行
docker volume create --name redis_cluster_data3

2: 创建redis专用的网络

#--driver overlay  --attachable 表示创建swarm集群网络且不是service的容器也能加入此网络
docker network create --driver overlay \
--attachable --subnet=192.169.0.0/24 redis_cluster_network

3:下载/配置redis配置文件

本文使用redis6.2.6版本,所以下载redis6.2.6版本中的配置文件

点此进入redis官方文件列表

在这里插入图片描述
解压下载的文件,找到redis.conf文件
在这里插入图片描述

  • 修改默认配置文件
    • bind 127.0.0.1 #注释掉这部分,这是限制redis只能本地访问
    • protected-mode no #默认yes,开启保护模式,限制为本地访问
    • daemonize no#默认no,改为yes意为以守护进程方式启动,可后台运行,除非kill进程(可选),改为yes会使配置文件方式启动redis失败
    • dir ./ #输入本地redis数据库存放文件夹(可选)
    • appendonly yes #redis持久化(可选)

然后将此配置文件复制到docker数据卷所在位置(如果你不使用swarm就正常挂载文件就行)

4:创建redis集群service

新增node标签

docker node update --label-add redis=cluster node1
docker node update --label-add redis=cluster node2
docker node update --label-add redis=cluster node3

创建service

docker service create --name redis_cluster \
--network redis_cluster_network \
--mount type=volume,src=redis_cluster_data,dst=/data \
--replicas 3 --constraint 'node.labels.redis == cluster' \
redis:6.2.6 --appendonly yes

5:配置主从关系

选择要成为主节点的IP比如:192.168.31.130
进入从节点01,从节点02

docker exec -it redis_cluster1 redis-cli
docker exec -it redis_cluster2 redis-cli

输入以下命令加入主节点

#固定语法 slaveof 主节点IP 主节点端口
slaveof 192.168.1.10 6379

进入主节点查看节点数量是否成功加入

docker exec -it redis_cluster_master redis-cli
info

6:创建redis哨兵数据挂载卷

#node1机器上执行
docker volume create --name redis_sentinel_data1
#node2机器上执行
docker volume create --name redis_sentinel_data2
#node3机器上执行
docker volume create --name redis_sentinel_data3

下载/配置redis哨兵配置文件
由于上面已经下载了redis6.2.6所以我们接着使用文件夹的中的sentinel.conf文件
在这里插入图片描述
修改第84行的sentlnel参数,改为redis主节点的ip,端口
在这里插入图片描述
然后将此配置文件复制到docker数据卷所在位置(如果你不使用swarm就正常挂载文件就行)

7:创建redis哨兵集群service

docker service create --name redis_sentinel_cluster \
--network redis_cluster_network \
#挂载数据卷redis_sentinel_data到容器的/etc/redis目录下 \
--mount type=volume,src=redis_sentinel_data,dst=/etc/redis \
# 开放tcp端口且网络不走集群路由网络(如果不加mode=host,则默认每个docker节点的7369端口都会强制跳转到这些service中无论节点是否在此ndoe中) \
--publish published=7369,target=26379,protocol=tcp,mode=host \
# 制作3个副本 并指定符合条件的node节点中生成。\
--replicas 3 --constraint 'node.labels.redis == cluster' \
# 指定redis镜像版本,指定哨兵模式按指定配置文件启动
redis:6.2.6 redis-sentinel /etc/redis/sentinel.conf

查看哨兵节点信息

#进入哨兵节点
docker exec -it sentinel /bin/bash
#输入命令
redis-cli -h 127.0.0.1 -p 26379
#查看sentinel集群信息
info sentinel

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.kler.cn/a/3598.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

MP4怎么转换成MP3格式?两种方法帮你实现

MP4是一种常见的视频格式,而MP3则是一种音频格式。有时候,我们需要将MP4视频转换为MP3音频,例如从YouTube下载视频后只需要提取其中的音频部分。以下是两种方法帮助您实现MP4到MP3的转换。 方法一:使用在线转换工具 在线转换工具…

搭建一个双系统个人服务器

搭建一个双系统个人服务器0.前言一、双系统安装1.磁盘划分2.windows安装3.ubuntu安装二、系统启动项美化:1. refind引导2. 美化 grub 界面三、系统代理0.前言 年后找了份工作,忙于适应新环境所以更新也减缓了,最近闲暇时间给个人电脑进行了整…

水果新鲜程度检测系统(UI界面+YOLOv5+训练数据集)

摘要:水果新鲜程度检测软件用于检测水果新鲜程度,利用深度学习技术识别腐败或损坏的水果,以辅助挑拣出新鲜水果,支持实时在线检测。本文详细介绍水果新鲜程度检测系统,在介绍算法原理的同时,给出Python的实…

dfs和bfs能解决的问题

一.理解暴力穷举之dfs和bfs暴力穷举暴力穷举是在解决问题中最常用的手段,而dfs和bfs算法则是这个手段的两个非常重要的工具。其实,最简单的穷举法是直接遍历,如数列求和,遍历一个数组即可求得所问答案,这与我在前两篇博…

给准备面试网络工程师岗位的应届生一些建议

你听完这个故事,应该会有所收获。最近有一个23届毕业的大学生和我聊天,他现在网络工程专业大四,因为今年6、7月份的时候毕业,所以现在面临找工作的问题。不管是现在找一份实习工作,还是毕业后找一份正式工作&#xff0…

QT表格控件实例(Table Widget 、Table View)

欢迎小伙伴的点评✨✨,相互学习🚀🚀🚀 博主🧑🧑 本着开源的精神交流Qt开发的经验、将持续更新续章,为社区贡献博主自身的开源精神👩‍🚀 文章目录前言一、图示实例二、列…

Cookie 和 Session的区别

文章目录时间:2023年3月23日第一:什么是 Cookie 和 Session ?什么是 Cookie什么是 Session第二:Cookie 和 Session 有什么不同?第三:为什么需要 Cookie 和 Session,他们有什么关联?第四&#x…

Python接口自动化 ❀ 详解 Cookie-Session登录验证 的工作原理

Python接口自动化 ❀ 详解 Cookie-Session登录验证 的工作原理前言1、Cookie&Session❀ 为什么不能单独使用Cookie?❀ Session是如何与Cookie结合的?2、Cookie&Session的缺陷❀ 存储问题❀CSRF问题3、session和cookie的区别与联系前言 目前绝大…

机器学习:基于KNN对葡萄酒质量进行分类

机器学习:基于KNN对葡萄酒质量进行分类 作者:i阿极 作者简介:Python领域新星作者、多项比赛获奖者:博主个人首页 😊😊😊如果觉得文章不错或能帮助到你学习,可以点赞👍收藏…

【SpringAOP】AOP面向切面编程

目录 一、什么是AOP 二、为什么有AOP 三、AOP相关概念 四、SpringAOP代码案例 1、添加SpringAOP依赖 2、定义切面 3、定义切点 4、实现通知 一、什么是AOP AOP:AOP—Aspect Oriented Programming(面向切面编程),是对OOP&…

微信小程序面试题(day08)

文章目录微信小程序自定义组件的使用?微信小程序事件通道的使用?微信小程序如何使用vant组件库?微信小程序自定义组件父传子子传父?微信小程序自定义组件生命周期有哪些?微信小程序授权登录流程?web-view。…

OpenHarmony实战STM32MP157开发板 “控制” Hi3861开发板 -- 中篇

一、前言 我们在 OpenHarmony实战STM32MP157开发板 “控制” Hi3861开发板 – 上篇 中介绍到了,App面板的开发,以及JS API接口的开发和调用。 那么本篇文章,会详解:BearPi-HM Nano开发板,如何实现数据上报和指令接收响应的。 看到这里,可能有同学可能已经知道思路了,因…

【2023年第十一届泰迪杯数据挖掘挑战赛】B题:产品订单的数据分析与需求预测 建模及python代码详解 问题一

相关链接 【2023年第十一届泰迪杯数据挖掘挑战赛】B题:产品订单的数据分析与需求预测 建模及python代码详解 问题一 【2023年第十一届泰迪杯数据挖掘挑战赛】B题:产品订单的数据分析与需求预测 建模及python代码详解 问题二 1 题目 一.问题…

Java中的深拷贝和浅拷贝

目录 🍎引出拷贝 🍎浅拷贝 🍎深拷贝 🍎总结 引出拷贝 现在有一个学生类和书包类,在学生类中有引用类型的书包变量: class SchoolBag {private String brand; //书包的品牌private int size; //书…

记一次若依后台管理系统渗透

前言 最近客户开始hw前的风险排查,让我们帮他做个渗透测试,只给一个单位名称。通过前期的信息收集,发现了这个站点: 没有验证码,再加上这个图标,吸引了我注意: 从弱口令开始 若依默认口令为ad…

学习操作系统的必备教科书《操作系统:原理与实现》| 文末赠书4本

使用了6年的实时操作系统,是时候梳理一下它的知识点了 摘要: 本文简单介绍了博主学习操作系统的心路历程,同时还给大家总结了一下当下流行的几种实时操作系统,以及在工程中OSAL应该如何设计。希望对大家有所启发和帮助。 文章目录…

Java中的日期时间类

日期时间类一、JDK8之前日期时间二、JDK8中日期时间一、JDK8之前日期时间 1. 获取时间:System.currentTimeMillis() 关于计算时间的标准可参考https://baijiahao.baidu.com/s?id1732139602203523267&wfrspider&forpc 我国处于东八区,与中时区时…

K8S + GitLab + Jenkins自动化发布项目实践(一)

K8S GitLab Jenkins自动化发布项目实践(一)发布流程设计安装Docker服务部署Harbor作为镜像仓库部署GitLab作为代码仓库常用Git命令发布流程设计 #mermaid-svg-pe9VmFytb9GmqMvG {font-family:"trebuchet ms",verdana,arial,sans-serif;font-…

关于Docker逃逸

关于Docker逃逸 文章目录关于Docker逃逸前言一、判断是否为docker容器?二、privileged特权模式启动容器逃逸三、 Docker Remote API未授权访问逃逸四、危险挂载导致Docker逃逸五、危险挂载Docker Socket逃逸六、 挂载宿主机procfs逃逸七、脏牛漏洞来进行docker逃逸八…

【Spring Cloud Alibaba】7.Sentinel熔断器仪表盘监控

文章目录简介什么是 Sentinel控制台获取源码方式下载jar包方式启动访问服务配置项目,启用Sentinel完整配置测试简介 接下来我们通过Sentinel控制台来实现对服务消费者提供的熔断机制进行监控和控制,本操作先要完成之前的步骤,详情请参照【Sp…
最新文章