redis集群failover-redis集群从节点宕机恢复(8-4-65)
更新时间:2024-11-13 分类:Redis 浏览量:2
Redis本文目录一览:
- 1、为什么Redis数据库内存不宜过大
- 2、Redis集群检测与恢复
- 3、Redis哨兵机制原理浅析
- 4、redis宕机了怎么办
- 5、简介redis之哨兵集群搭建
- 6、redis数据量过大怎么办
为什么Redis数据库内存不宜过大
1、如果此时主库内存体积过大那么从库重做速度就会很慢,而发送到从库的读请求就会受到严重影响,同时由于传输的rdb文件的体积过大,主库的网卡在相当长的一段时间内都会受到严重影响。
2、单台Redis的存放数据必须比物理内存小 Redis的数据全部放在内存带来了高速的性能,但是也带来一些不合理之处。比如一个中型网站有100万注册用户,如果这些资料要用Redis来存储,内存的容量必须能够容纳这100万用户。
3、在数据库方面,mysql是关系型数据库主要用于存放持久化数据,redis是NOSQL,即非关系型数据库,也是缓存数据库,缓存的读取速度快,能够大大的提高运行效率,但是保存时间有限。
Redis集群检测与恢复
需要使用trib的fix命令进行修复。如果修复还是不行的话,可以清除节点数据再重新建集群,前提要备份之后操作。
关机并重启需要关机的服务器。Copy codesudo systemctl stop 服务器名称 sudo systemctl restart 服务器名称 其中 服务器名称 是需要关机和重启的服务器名称。检查 Redis 集群是否正常工作。
AOF 方法进行故障恢复的时候,需要逐一把操作日志都执行一遍。如果操作日志非常多,Redis 就会恢复得很缓慢,影响到正常使用。RDB 既可以保证可靠性,还能在宕机时实现快速恢复。
Redis哨兵适用于单节点或者主从复制的场景,可以通过哨兵节点来实现Redis的自动切换和故障恢复。Redis集群则是一种分布式的Redis解决方案,可以将数据分散到多个节点上,提高数据存储和读取的性能。
验证redis分片集群是否搭建成功的步骤为:在redis分片集群创建目录。成功就是搭建成功了。失败就是搭建失败。
Redis哨兵机制原理浅析
1、原理 监控 sentinel节点需要监控master、slave以及其他sentinel节点的状态。这一过程是通过Redis的pub\sub系统实现的。
2、Redis哨兵模式的实现原理。关于哨兵的原理,关键是了解以下几个概念:定时任务:每个哨兵节点维护了3个定时任务。
3、Redis的哨兵机制就是解决主从复制存在缺陷(选举问题),解决问题保证我们的Redis高可用,实现自动化故障发现与故障转移。 要使用哨兵机制,除了启动Redis服务以外,还要启动哨兵服务来进行监控,会介绍详细步骤。
4、其原理是哨兵通过发送命令,等待Redis服务器响应,如果Redis服务器一直没有响应,说明这个Redis服务器可能已经宕机了,从而监控运行的多个Redis实例。
redis宕机了怎么办
1、常见解决方案:在命令窗口输入:ping [IP] 查看是否有连接,如果没有,则为网络问题,如果有,尝试第二步。
2、一般选择on-failure,也就是非正常宕机都重启,手动停止不重启。
3、假如master宕机了,Redis本身(包括它的很多客户端)都没有实现自动进行主备切换,而Redis-sentinel本身也是一个独立运行的进程,它能监控多个master-slave集群,发现master宕机后能进行自懂切换。
4、使用 Redis 的 AOF(Append Only File)机制:Redis 可以将所有写入操作以追加的方式保存到一个 AOF 文件中,如果出现宕机等问题,可以使用 AOF 文件进行恢复。
5、单个Redis服务如果宕机的话,服务就不可用了,为了解决这种问题,redis也提供有集群服务。传统的Redis集群采用的主从复制模式,一般为一主多从,主节点有读写权限,但是从节点只有读的权限。
6、问题-1 如果setnx执行成功,但是在expire执行的时候redis节点宕机了,在这种情况下,锁不会被释放,导致死锁。
简介redis之哨兵集群搭建
基本和主节点差不多,但要加上 slaveof 配置和主节点账号密码。
配置哨兵模式:Redis Sentinel集群通常由3到5个节点组成,如果个别节点挂了,集群还可以正常运作。Sentinel负责监控Redis集群的 健康 情况。如果主Redis挂掉,Sentinel集群会通过投票选择一个新的主Redis。
搭建集群工作需要以下三个步骤:1)准备节点。2)节点握手。3)分配槽。Redis集群一般由多个节点组成,节点数量至少为6个才能保证组成完整高可用的集群。每个节点需要开启配置cluster-enabled yes,让Redis运行在集群模式下。
哨兵模式是在主备模式的基础上,加上哨兵,实现redis集群的故障转移。哨兵负责监控集群状态,当redis主节点发生故障,哨兵通过选举,选出替代的master节点。一般需要单数的哨兵进行选举,大多数达成一致。
通过发送命令,让Redis服务器返回监控其运行状态,包括主服务器和从服务器。当哨兵监测到master宕机,会自动将slave切换成master,然后通过 发布订阅模式 通知其他的从服务器,修改配置文件,让它们切换主机。
redis数据量过大怎么办
客户端与redis节点直连,不需要连接集群所有的节点,连接集群中任何一个可用节点即可。redis-trib.rb脚本(rub语言)为集群的管理工具,比如自动添加节点,规划槽位,迁移数据等一系列操作。
解决办法 在客户端将连接进行池化,同时对客户端读写Redis操作采用内部锁synchronized。服务器角度,利用setnx变向实现锁机制。
可以尝试优化Redis的内存配置,如使用更高效的数据结构、通过分片方式扩容等。操作数据过大:如果set操作要处理的数据量过大,会导致操作耗时增加。可以尝试减小set操作要处理的数据量,如拆分为多个操作、使用批量操作等。