Redis集群模式1-主从复制+哨兵机制传统的Redis集群采用的主从复制模式 , 一般为一主多从,主节点有读写权限,但是从节点只有读的权限 。主节点会定期将数据同步到从节点中,保证数据一致性的问题 。
Redis 高可用的主要有三种模式: 主从模式,哨兵模式和集群模式 。Redis 提供了 Redis 提供了复制(replication)功能,当一台 redis 数据库中的数据发生了变化 , 这个变化会被自动地同步到其他的 redis 机器上去 。
因此, 主从模式的一个缺点,就在于无法实现自动化地故障恢复。Redis后来引入了哨兵机制 , 哨兵机制大大提升了系统的高可用性 。哨兵,就是站岗放哨的,时刻监控周围的一举一动,在第一时间发现敌情并发出及时的警报 。
Redis早期的主从架构原理分析,早期如何实现读写分离的?1、读写分离: 可以用于实现读写分离,主库写、从库读 , 读写分离不仅可以提高服务器的负载能力,同时可根据需求的变化,改变从库的数量 。
2、一种是先写入mysql , 然后再写入redis 。这样实现方便,每次只要redis不存在,就从mysql获取数据即可,缺点也明显,有一定的数据延迟 。数据一致性要求不高的场合可以使用这种方式 。
3、主从复制可以将写操作集中在主节点,仅让从节点负责读取数据,从而实现读写分离,并提高Redis集群的性能 。
4、上一篇文章Redis主从复制原理中简要地说明了主从复制的一个基本原理,包含全量复制、复制积压缓冲区与增量复制等内容,有兴趣的同学可以先看下 。利用主从复制,可以实现读写分离、数据备份等功能 。
redis怎么迁移数据?1、配置迁移链路 在NineData中创建迁移任务 , 选择源和目标实例,并配置复制类型为数据迁移 。根据需要选择合适的冲突处理策略 。选择迁移对象 在迁移任务中 , 选择要迁移的Redis数据库和数据表 。
2、选择复制类型,数据迁移应选择结构和全量复制(数据迁移) 。根据需要 , 选择合适的冲突处理策略 。选择要迁移的数据库对象 。配置映射关系,将源实例的多个数据库(0~15)映射到目标实例的指定1个或多个数据库 。
3、Redis数据迁移方案推荐使用NineData数据复制工具 。相较于传统迁移方案 , NineData提供了更强大、更高效的迁移方案 。
脑裂以及Redis主从同步中的坑所谓的脑裂,就是指在主从集群中,同时有两个主节点,它们都能接收写请求 。而脑裂最直接的影响,就是客户端不知道应该往哪个主节点写入数据,结果就是不同的客户端会往不同的主节点上写入数据 。
因为 master - slave的复制是异步 的(客户端发送给redis,主节点数据同步到内存中后就返回成功了) 所以可能有部分数据还没复制到slave , master就宕机了,此时master内存中的数据也没了,这些部分数据就丢失了 。
redis集群没有过半机制会有脑裂问题,网络分区导致脑裂后多个主节点对外提供写服务,一旦网络分区恢复,会将其中一个主节点变为从节点,这时会有大量数据丢失 。
redis的集群脑裂是指因为网络问题,导致redis master节点跟redis slave节点和sentinel集群处于不同的网络分区,此时因为sentinel集群无法感知到master的存在 , 所以将slave节点提升为master节点 。
玩转Redis的高可用(主从、哨兵、集群)Redis主从复制是指在一个Redis集群中,将一个Redis节点作为主节点,其余的Redis节点作为从节点 。主节点负责写入数据,从节点负责读取数据 。
Redis的哨兵机制就是解决主从复制存在缺陷(选举问题) , 解决问题保证我们的Redis高可用,实现自动化故障发现与故障转移 。要使用哨兵机制,除了启动Redis服务以外,还要启动哨兵服务来进行监控,会介绍详细步骤 。
【配置redis主从同步的简单介绍】redis高可用:如果你做主从架构部署,其实就是加上哨兵就可以了,就可以实现,任何一个实例宕机,自动会进行主备切换 。
哨兵模式就是在主从模式的基础上再加一个哨兵集群 。每个哨兵都会监控主节点和从节点的状态 。如果主节点挂了,就会从从节点中选出一个来作为主节点,以达到高可用的目的 。
redis哨兵和集群不能同时使用,Redis哨兵和集群是两种不同的Redis高可用方案 。
推荐阅读
- 如何快速打开服务器设置的快捷键? 怎么快捷键调出服务器设置
- redis使用技巧 redis简单实用
- 如何选择适合自己的服务器型号? 组装服务器怎么选型号啊
- 服务器怎么查看数据库的名称 怎么调取服务器的数据库
- 如何使用快捷键快速连接服务器? 怎么快捷键调出服务器
- redis客户端链接命令 redis如何检测客户端和服务端链接