Sentinel
Sentinel 进程是用于监控 redis 集群中 Master 主服务器工作的状态,在 Master 主服务器发生故障的时候,可以实现 Master 和 Slave 服务器的切换,保证系统的高可用,其已经被集成在 redis2.6+的版本中,Redis 的哨兵模式到了 2.8 版本之后就稳定了下来。一般在生产环境也建议使用 Redis 的 2.8 版本的以后版本。哨兵 (Sentinel) 是一个分布式系统,你可以在一个架构中运行多个哨兵 (sentinel) 进程, 这些进程使用流言协议 (gossipprotocols) 来接收关于 Master 主服务器是否下线的信息,并使用投票协议 (Agreement Protocols) 来决定是否执行自动故障迁移,以及选择哪个 Slave 作为新的 Master。每个哨兵 (Sentinel) 进程会向其它哨兵 (Sentinel)、Master、Slave 定时发送消息,以确认对方是否 ”活” 着,如果发现对方在指定配置时间 (可配置的) 内未得到回应,则暂时认为对方已掉线,也就是所谓的 ”主观认 为宕机” ,英文名称:Subjective Down,简称 SDOWN。有主观宕机,肯定就有客观宕机。当“哨兵 群”中的多数 Sentinel 进程在对 Master 主服务器做出 SDOWN 的判断,并且通过 SENTINEL is-masterdown-by-addr 命令互相交流之后,得出的 Master Server 下线判断,这种方式就是 “客观宕机”,英文名称是:Objectively Down, 简称 ODOWN。通过一定的 vote 算法,从剩下的 slave 从服务器节点中,选一台提升为 Master 服务器节点,然后自动修改相关配置,并开启故障转移(failover)。
Sentinel 机制可以解决 master 和 slave 角色的切换问题。
Sentinel 配置
- 配置文件
####### Node 1 #######
~]# vim /usr/local/redis/etc/sentinel.conf
bind 172.18.33.101
port 26379
daemonize yes
pidfile "/usr/local/redis/run/redis-sentinel.pid"
logfile "/usr/local/redis/logs/sentinel_26379.log"
dir "/usr/local/redis"
sentinel deny-scripts-reconfig yes
sentinel monitor mymaster 172.18.33.101 6379 2 # 投票机制,过半数
sentinel auth-pass mymaster 123456
####### Node 2 #######
~]# vim /usr/local/redis/etc/sentinel.conf
bind 172.18.33.102
port 26379
daemonize yes
pidfile "/usr/local/redis/run/redis-sentinel.pid"
logfile "/usr/local/redis/logs/sentinel_26379.log"
dir "/usr/local/redis"
sentinel deny-scripts-reconfig yes
sentinel monitor mymaster 172.18.33.101 6379 2 # 投票机制,过半数
sentinel auth-pass mymaster 123456
####### Node 3 #######
~]# vim /usr/local/redis/etc/sentinel.conf
bind 172.18.33.103
port 26379
daemonize yes
pidfile "/usr/local/redis/run/redis-sentinel.pid"
logfile "/usr/local/redis/logs/sentinel_26379.log"
dir "/usr/local/redis"
sentinel deny-scripts-reconfig yes
sentinel monitor mymaster 172.18.33.101 6379 2 # 投票机制,过半数
sentinel auth-pass mymaster 123456
image.png
网友评论