关于Redis的主从复制及哨兵问题
知识点掌握了,还需要不断练习才能熟练运用。下面golang学习网给大家带来一个数据库开发实战,手把手教大家学习《关于Redis的主从复制及哨兵问题》,在实现功能的过程中也带大家重新温习相关知识点,温故而知新,回头看看说不定又有不一样的感悟!
服务器配置
到这里关于redis的一些基本操作就学习完了,接下来我们就来看看redis中更加高级的部分,首先是配置文件中的配置信息。
配置项 | 说明 |
---|---|
daemonize yes | no |
bind 127.0.0.1 | 绑定主机地址 |
port 6379 | 设置服务器端口号 |
databases 16 | 设置数据库数量 |
loglevel debug | verbose |
logfile 端口号.log | 设置日志文件名 |
maxclients 0 | 设置同一时间最大客户端连接数,默认无限制,当客户端连接达到上限时,redis会关闭新的连接 |
timeout 300 | 客户端闲置等待最大时长,达到最大值后关闭连接,如需关闭该功能, 设置为0 |
include /path/server-端口号.conf | 导入并加载指定配置文件信息,用于快速创建redis公共配置较多的redis实例配置文件,便于维护 |
主从复制
现在我们只是在使用一个redis,它就会出现一些问题,比如服务器宕机后,该服务器上的redis将无法提供服务,而此时应用又只有一个redis服务支撑,那么我们的业务将无法提供正常的服务,为了保证高可用,我们需要为redis搭建集群。
redis中以master为主机,slave为从机,一个master可以对应多个slave,而一个slave只能对应一个master。
那么首先我们需要建立slave到master的连接,使master能够识别slave,并保存slave的端口号,启动四个窗口模拟这一过程:
在6380服务和6381服务窗口分别开启6380端口、6381端口的redis服务,然后来到slave窗口:
redis-cli -p 6381 slaveof 127.0.0.1 6380
这里表示使用6381端口连接6380端口,作为它的从机,此时我们再来到master窗口,连接客户端:
redis-cli -p 6380 set name zs
会发现,slave窗口中6381端口的redis也能够获取到该数据,此时证明主从搭建好了。
我们也可以在启动redis服务的时候就进行连接:
redis-server redis-6381.conf --slaveof 127.0.0.1 6380
redis推荐使用配置文件的方式搭建主从结构,修改redis-6381.conf:
slaveof 127.0.0.1 6380
此时6381就成了6380的从机了。
哨兵
在主从的环境下也可能会产生问题,比如作为主机的master服务宕机了,此时作为它的从机都无法正常工作了,这个时候我们需要在slave中选出一个作为新的master,以支撑主从继续提供服务。
哨兵则是为了解决上述问题的,它是一个分布式的系统,用于对主从结构中的每台服务器进行监控,当出现故障时通过投票机制选择新的master并将所有的slave连接到新的master。
哨兵的启动方式如下:
redis-sentinel sentinel.conf
哨兵的客户端链接方式:
redis-cli -p 26379
需要注意的是哨兵客户端不支持数据操作,它只作监控用途。
以上就是《关于Redis的主从复制及哨兵问题》的详细内容,更多关于redis的资料请关注golang学习网公众号!

- 上一篇
- Redis+Caffeine两级缓存的实现

- 下一篇
- Redis生成全局唯一ID的实现方法
-
- 兴奋的糖豆
- 这篇文章内容出现的刚刚好,太全面了,很好,已加入收藏夹了,关注师傅了!希望师傅能多写数据库相关的文章。
- 2023-01-13 15:39:30
-
- 数据库 · Redis | 9小时前 | redis Django 缓存 settings.py django-redis
- Django项目Redis缓存集成详解步骤
- 458浏览 收藏
-
- 数据库 · Redis | 1天前 |
- Redis启动时如何指定配置文件
- 225浏览 收藏
-
- 数据库 · Redis | 1天前 |
- Redis启动后无法访问?排查与解决攻略
- 498浏览 收藏
-
- 数据库 · Redis | 2天前 |
- Redis启动后访问异常?快速排查与解决
- 206浏览 收藏
-
- 数据库 · Redis | 2天前 |
- 检查Redis版本及升级指南
- 335浏览 收藏
-
- 数据库 · Redis | 3天前 |
- 检查Redis版本及升级指南
- 134浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 笔灵AI生成答辩PPT
- 探索笔灵AI生成答辩PPT的强大功能,快速制作高质量答辩PPT。精准内容提取、多样模板匹配、数据可视化、配套自述稿生成,让您的学术和职场展示更加专业与高效。
- 15次使用
-
- 知网AIGC检测服务系统
- 知网AIGC检测服务系统,专注于检测学术文本中的疑似AI生成内容。依托知网海量高质量文献资源,结合先进的“知识增强AIGC检测技术”,系统能够从语言模式和语义逻辑两方面精准识别AI生成内容,适用于学术研究、教育和企业领域,确保文本的真实性和原创性。
- 24次使用
-
- AIGC检测-Aibiye
- AIbiye官网推出的AIGC检测服务,专注于检测ChatGPT、Gemini、Claude等AIGC工具生成的文本,帮助用户确保论文的原创性和学术规范。支持txt和doc(x)格式,检测范围为论文正文,提供高准确性和便捷的用户体验。
- 30次使用
-
- 易笔AI论文
- 易笔AI论文平台提供自动写作、格式校对、查重检测等功能,支持多种学术领域的论文生成。价格优惠,界面友好,操作简便,适用于学术研究者、学生及论文辅导机构。
- 42次使用
-
- 笔启AI论文写作平台
- 笔启AI论文写作平台提供多类型论文生成服务,支持多语言写作,满足学术研究者、学生和职场人士的需求。平台采用AI 4.0版本,确保论文质量和原创性,并提供查重保障和隐私保护。
- 35次使用
-
- Redis教程(九):主从复制配置实例
- 2023-01-08 374浏览
-
- Redis主从复制和容量扩展问题的解决方案
- 2023-01-29 100浏览
-
- 图解Redis主从复制与Redis哨兵机制
- 2023-05-13 377浏览