什么是redis集群
Redis 集群是一个分布式(distributed)、容错(fault-tolerant)的 Redis 实现, 集群可以使用的功能是普通单机 Redis 所能使用的功能的一个子集(subset)。
改用 C语言编写的 redis-cli的方式,是集群的构建方式复杂度大大降低。Redis-Cluster集群采用无中心结构,每个节点保存数据和整个集群状态,每个节点都和其他所有节点连接。
redis集群:数据存放在节点内的一组或多组槽(slot)中,节点本身分为主节点和备用节点,当某个主节点挂掉时,其备用节点可被提升为主节点。
Redis哨兵适用于单节点或者主从复制的场景,可以通过哨兵节点来实现Redis的自动切换和故障恢复。Redis集群则是一种分布式的Redis解决方案,可以将数据分散到多个节点上,提高数据存储和读取的性能。
玩转Redis的高可用(主从、哨兵、集群)
基于以上,Redis集群方案显得尤为重要。通常有3个途径:官方Redis Cluster;通过Proxy分片;客户端分片(Smart Client)。以上三种方案各有利弊。
Redis主从复制是指在一个Redis集群中,将一个Redis节点作为主节点,其余的Redis节点作为从节点。主节点负责写入数据,从节点负责读取数据。
主节点会定期将数据同步到从节点中,保证数据一致性的问题。这种集群方式在运行时存在一些问题:Redis的哨兵机制就是解决主从复制存在缺陷(选举问题),解决问题保证我们的Redis高可用,实现自动化故障发现与故障转移。
哨兵模式就是在主从模式的基础上再加一个哨兵集群。每个哨兵都会监控主节点和从节点的状态。如果主节点挂了,就会从从节点中选出一个来作为主节点,以达到高可用的目的。
Redis主从复制丢失数据的情况分析
Redis中的Map被误删除:在某些情况下,可能会出现误删除Map的情况,例如在操作时误执行了DEL命令或者使用了错误的键名。
这样一来,主从切换完成后,也只有新主库能接收请求,不会发生脑裂,也就不会发生数据丢失的问题了。主从数据不一致,就是指客户端从从库中读取到的值和主库中的最新值并不一致。
可能有人会遇到,Redis 经常会丢掉一些数据,写进去了,过一会儿可能就没了。那么你可能是将Redis当成存储了而没有当作缓存。啥叫缓存?用内存当缓存。内存是无限的吗,内存是很宝贵而且是有限的,磁盘是廉价而且是大量的。
异步复制导致的数据丢失 哨兵可以解决主从架构下,因master宕机后不能接收写请求而进行选举salve为新的master,达到高可用的效果。
简介redis之主从复制
Redis主从复制可以将写入操作集中在主节点,提高写入性能。同时从节点负责读取数据,可以分担主节点的读取负担,提高读取性能。
Redis中主从节点复制数据有全量复制和部分复制之分。
传统的Redis集群采用的主从复制模式,一般为一主多从,主节点有读写权限,但是从节点只有读的权限。主节点会定期将数据同步到从节点中,保证数据一致性的问题。
Redis迁移数据有多种方法,包括使用RDB和AOF文件、主从复制以及使用专门的工具。
利用主从复制,可以实现读写分离、数据备份等功能。但如果主库宕机后,需要运维人员手动地将一个从库提升为新主库,并将其他从库slaveof新主库,以此来实现故障恢复。
Redis为复制积压缓冲区设置的默认大小为1MB,如果主服务器需要执行大量写命令,又或者主从服务器断线后重连接所需的时间比较,那么这个大小也许并不合适。
常见分布式集群选举机制总结
1、Zookeeper的选举机制有2个触发条件:集群启动阶段和集群运行阶段leader挂机。这2种场景下选举的流程基本一致,我们以集群运行阶段leader挂机为例来进行说明。
2、Quorums(法定人数), 过半机制 :默认方式,比如3个节点的集群,Quorums = 2, 也就是说集群可以容忍1个节点失效,这时候还能选举出1个leader,集群还可用。
3、一,Zookeeper选举过程中服务器的状态。LOOKING:寻找leader状态,该状态下,服务器认为当前集群没有leader,会发起leader选举。在选举过程中,所有服务器的状态都是LOOKING。
redis选举与复制的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于redis sentinel 选举、redis选举与复制的信息别忘了在本站进行查找喔。