Redis 主从 + 哨兵模式搭建

news2024/9/23 17:23:51

前言:以Linux环境为示例

一、整体架构(1主 + 2从 + 3哨兵)

二、redis 安装

1、安装路径:/usr/local/redis/redis-6382(可自行指定)

2、解压安装包:

直接解压:tar -axvf redis-5.0.10.tar.gz 

或

解压到指定路径:tar -axvf redis-5.0.10.tar.gz -C /usr/local/redis/redis-6382

 3、进入解压后的/redis-5.0.10/src下,执行make命令并指定安装路径:

make PREFIX=/usr/local/redis/redis-6382 install 

开始安装:

 安装后:

4、因为要满足:1主+2从+3哨兵 的框架,所以需要安装6个redis,因为是在同一台虚拟机上,所以端口分别用:6379(主)、6380(从)、6381从)、26379(哨兵)、26380(哨兵)、26381(哨兵),如果条件允许,有6台不同的服务器,6个redis的端口均可设置成一样

三、redis配置

1、主库配置

在 redis 安装 bin目录下,创建 redis.conf 文件,并进行配置

# 修改redis配置文件:redis.conf

# 1. 修改绑定ip为服务器内网ip地址,做绑定,三台各自填写各自的ip地址
bind 0.0.0.0
# 2. 设置端口
port 6379
# 3. 保护模式修改为否,允许远程连接
protected-mode no
# 4. 设定密码
requirepass "123456"
# 5. 设定主库密码与当前库密码同步,保证从库能够提升为主库
masterauth "123456"
# 6. 打开AOF持久化支持
appendonly yes
# 7. 输入日志信息
logfile ./redis.log
# 8. 守护进程模式启动
daemonize yes 

2、从库配置

在 redis 安装 bin目录下,创建 redis.conf 文件,并进行配置

# 修改redis配置文件:redis.conf

# 1. 修改绑定ip为服务器内网ip地址,做绑定,三台各自填写各自的ip地址
bind 0.0.0.0
# 2. 设置端口
port 6379
# 3. 保护模式修改为否,允许远程连接
protected-mode no
# 4. 设定密码
requirepass 123456
# 5. 设定主库密码与当前库密码同步,保证从库能够提升为主库
masterauth 123456
# 6. 打开AOF持久化支持
appendonly yes
# 7. 输入日志信息
logfile ./redis.log
# 8. 守护进程模式启动
daemonize yes
# 9.主库为主虚拟机1的地址
slaveof 192.168.230.133 6379

3、哨兵配置

在 redis 安装 bin目录下,创建 sentinel.conf 文件,并进行配置

# 修改redis-sentinel配置文件:redis-sentinel.conf

# 1. 绑定的地址
bind 0.0.0.0
# 2. 设置端口
port 6379
# 3. 保护模式修改为否,允许远程连接
protected-mode no
# 4. 守护进程模式启动
daemonize yes
# 5. 输入日志信息
logfile ./sentinel.log
# 6. 设定sentinel myid 每个都不一样,使用yum安装的时候,直接就生成了
sentinel myid f761aa37bc8dd70a0ba6ace5d5bef7fb1a49cc14
# 7. 设定监控地址,为对应的主redis库的内网地址
sentinel monitor mymaster 192.168.230.133 6379 2
# 8. 设定5秒内没有响应,说明服务器挂了,需要将配置放在sentinel monitor mymaster 192.168.230.133 6379 2下面
sentinel down-after-milliseconds mymaster 5000
# 9. 设定15秒内master没有活起来,就重新选举主
sentinel failover-timeout mymaster 15000
# 10. 表示如果master重新选出来后,其它slave节点能同时并行从新master同步缓存的台数有多少个,显然该值越大,所有slave节点完成同步切换的整体速度越快,但如果此时正好有人在访问这些slave,可能造成读取失败,影响面会更广。最保定的设置为1,只同一时间,只能有一台干这件事,这样其它slave还能继续服务,但是所有slave全部完成缓存更新同步的进程将变慢。
sentinel parallel-syncs mymaster 2
# 11. 主数据库密码,需要将配置放在sentinel monitor master 192.168.230.133 6379 2下面
sentinel auth-pass mymaster 123456

四、启动

1、启动主库(6379)
1.1、启动:./redis-server redis.conf

1.2、进入redis-6379服务:./redis-cli -p 6379

1.3、认证:auth pwd

1.4、查看数据库信息:info replication

2、启动从库(6380 和 6381)

2.1、启动:./redis-server redis.conf

2.2、进入redis-6380服务:./redis-cli -p 6380

2.3、认证:auth pwd

2.4、查看数据库信息:info replication

3、启动哨兵(26379 、26381 和 26382)

3.1、启动:./redis-sentinel sentinel.conf

3.2、进入redis-26379服务:./redis-cli -p 26379

3.3、查看数据库信息:info sentinel

五、测试

1、主/从同步测试

主库写入

从库读取

2、从库只读性测试

3、主/从切换测试

 停用6379前

  停用6379后

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

国内可以使用的chatgpt站点,有多种工具可用

看到很多人在寻找国内可以使用的chatgpt站点,忍不住来给大家分享一波,这个相对而言还是挺好用的,不限制字数,每天都能白女票使用。看下面正文。 chatgpt的使用方法 在浏览器或者打开我的电脑,顶部车俞入 人工智能聊…

C++好难(5):内存管理

这一节学完,我们 C嘎嘎 就算是正式入门了,但是之后的课还会更上一阶d(ŐдŐ๑) 继续坚持! 【本节目标】 1. C/C内存分布 2. C语言中动态内存管理方式 3. C中动态内存管理 4. operator new与operator delete函数 5. new和delete的实现原…

【在线OJ项目】项目环境与项目演示

目录 一、项目环境 二、项目展示 项目Gitee地址:online-oj: 在线OJ项目实现了核心模块,后续添加竞赛、考试等 (gitee.com)https://gitee.com/PG1886/online-oj 一、项目环境 采用SpringBootSpringMVCMybatis进行服务器开发 前端采用HTMLCSSJS&#…

mysql 5.7.32安装及主从安装信息

最方便的 就是 直接使用docker容器 搭建一个比较方便 或者 直接使用yum源安装,说白了就是少踩坑。 或者 是直接使用 宝塔等工具帮忙,直接脚本跑 宝塔面板 - 简单好用的Linux/Windows服务器运维管理面板 以下是内网两台机器安装的方法 1: 下…

【数据结构】ArrayList与顺序表

目录 1.List接口 2.线性表 3.顺序表 3.1常用方法 3.2常用方法的实现 4.ArrayList 4.1构造方法 4.2遍历 4.3扩容 4.4CVTE面试题:删除相同字符 5.ArrayList的具体实现 5.1洗牌算法 5.2杨辉三角 6.ArrayList的优缺点 1.List接口 List 接口继承于 Collec…

3 天,入门 TAURI 并开发一个跨平台 ChatGPT 客户端

TAURI 是什么 TAURI 是一个使用 Rust 编写的程序框架,它允许我们使用 Web 技术和 Rust 语言构建跨端应用。它提供了大量特性,例如系统通知、网络请求、全局快捷键、本地文件处理等,它们都可以在前端通过 JavaScript 便捷的调用。 TAURI 应用…

《精英的傲慢:好的社会该如何定义成功》笔记与摘录

目录 作者简介 书内容简介 经典摘录 1、现状与现象 2、什么是优绩至上原则 3、对优绩至上原则赞同与否的讨论 4、 优绩至上原则存在的争议点 5、 作为哲学家,桑德尔从道德哲学角度的思考 6、作者对优绩制的批判 7、流动性与平等的关系 8、我们该如何摆脱优…

MyCat分片-垂直分库

文章目录 需求场景一、环境准备二、实现1.MyCat—schema.xml文件配置2.MyCat—server.xml文件配置3.MyCat启动4.MyCat登录5.创建表结构及数据导入 三、全局表配置全局表配置 此文档来源于网络,如有侵权,请联系删除! 需求场景 在业务系统中,涉…

使用ChatGPT辅助学习——让你的学生主动找到学习的方法!

ChatGPT就像一座巨大的金矿,能挖到多少金子,完全取决于你的思维、认知和行动力。 当大部分人还在观望,或者拿着ChatGPT随便玩一玩的时候。 有的人,已经快速把它切入垂直领域,开始深耕。 如果你的孩子或者学生正在上初…

静态库和动态库的制作与使用

1.静态库的制作与使用 小知识:删除命令行,或者是配置好的路径之类的:退出编辑模式后:dd 保存并退出:退出编辑模式后,:wq (1)静态库的制作 1.首先生成你需要加入的文件的.O文件。使用如下代码 …

网络编程六--UDP服务器客户端

写在前面 UDP(User Datagram Protocol)称为用户数据报协议,是一种无连接的传输协议。 UDP的主要应用在即使丢失部分数据,也不影响整体效果的场景。例实时传输视频或音频时,即使丢失部分数据,也不会影响整…

C++11大杂烩

C11大杂烩 文章目录 C11大杂烩介绍语法统一的列表初始化:{}初始化initializer_list简化声明的方式autotypeid().name():获取类型名decltype nullptr范围for循环stl库中的一些变化arrayforward_list final和override右值引用和移动语义左值引用和右值引用 移动构造和…

有没有好用的UI在线设计工具?这5个设计师必备!

这篇文章介绍了 5 款在线UI设计工具,分别是即时设计、InVision Studio、Axure、Framer 和 Principle。其中,即时设计是一款次世代的在线协作UI设计工具,支持多人协同在线设计一键交付、插入交互式动画等功能,最近还更新了全球首款…

网络基础知识1—网络

文章目录 1.网络划分1.1局域网(内网)1.2广域网(公网) 2.网络的作用3.端口号3.1作用3.2两台主机中的进程传输数据3.3格式3.4注意 4.协议4.1概念4.2三要素4.3最终体现4.4作用 5.五元组5.1源IP5.2源端口5.3目的IP5.4目的端口5.5协议 …

MySQL中这14个神仙功能

1.group_concat 在我们平常的工作中,使用group by进行分组的场景,是非常多的。 比如想统计出用户表中,名称不同的用户的具体名称有哪些? 具体sql如下: select name from user group by name;但如果想把name相同的c…

IO 流学习总结

一:IO 流的概述 1. 什么是 IO 流? 存储和读取数据的解决方法 I:input O:output 流:像水流一样传输数据 2. IO 流的作用? 用于读写数据(本地文件,网络) 3. IO 流按…

三年亏百亿仍要造“跑车”,哪吒还有几次试错?

文丨智能相对论 作者丨leo陈 燃油车时代,国产品牌没有一款真正意义上成功的“低价跑车”,那在新能源时代,“电”是否可以创造这种可能? 第一个交出答卷的是哪吒汽车。不久前,哪吒发布首款纯电跑车“哪吒GT”&#x…

3个方法提高电脑运行速度,亲测有效!

案例:怎样提高电脑运行的速度? 【随着使用时间的增长,我的电脑运行速度越来越慢,这样我感到十分不方便和烦恼。有什么办法可以提高电脑的运行速度吗?】 在日常使用电脑过程中,我们难免会遇到电脑运行缓慢…

【C++】第13章: 类继承

文章目录 第十三章 类继承13.1 一个简单的基类13.1.1 派生一个类13.1.2 构造函数:访问权限的考虑13.1.3 使用派生类13.1.4 派生类和基类之间的特殊关系 13.2 继承:is-a关系13.3 多态公有继承13.4 静态联编与动态联编13.4.1 指针和引用类型的兼容性13.4.2…

Doris简介、部署、功能介绍以及架构设计

Doris简介、部署、功能介绍以及架构设计 1. Doris简介 Doris 中文官方文档:https://doris.apache.org/zh-CN/docs/dev/summary/basic-summary 1.1 Doris概述 ​ Apache Doris 是一个基于 MPP 架构的高性能、实时的分析型数据库,以极速易用的特点被人…