Redis高可用-Sentinel(哨兵)

Sentinel介绍

Sentinel 机制可以解决 master 和 slave 角色的切换问题

Redis 的 Sentinel 系统用于管理多个 Redis 服务器(instance), 该系统执行以下三个任务:

  • 监控 sentinel会不断地检查你的主服务器和从服务器是否运作正常。
  • 提醒 当被监控的某个redis服务器出现问题时,Sentinel可以通过API向管理员或者其他应用程序发送通知。
  • 自动故障迁移 当一个主服务器不能正常工作时,Sentinel会开始一次自动故障迁移操作,它会将失效的主服务器的其中一个从服务器升级为新的主服务器。当客户端试图链接失效的主服务器时,集群会向客户端返回新主服务器的地址。

Sentinel的前提是已经手动实现了一个redis的主从复制环境

配置文件 Sentinel.conf

每个节点有配置哨兵服务。

Ansible的模板文件 sentinel.conf.j2

复制代码
[root@ansible do_redis]# grep -E '^[a-Z]' /data/playbooks/do_redis/roles/redis/templates/sentinel.conf.j2 
bind 127.0.0.1 {{ ansible_default_ipv4['address'] }}
daemonize yes
port 26379
dir /usr/local/redis
pidfile "redis-sentinel.pid
logfile "sentinel-26379.log
sentinel monitor mymaster {{ master_ip }}  6379 2
sentinel auth-pass mymaster {{ redis_password }}
sentinel down-after-milliseconds mymaster 30000
sentinel parallel-syncs mymaster 1
sentinel failover-timeout mymaster 180000
sentinel deny-scripts-reconfig yes

服务脚本

复制代码
[root@ansible do_redis]# cat roles/redis/templates/sentinel.service.j2 
[Unit]
Description=Redis sentinel Server
After=network.target
[Service]
Type=forking
PIDFile=/usr/local/redis/redis-sentinel-26379.pid
User=redis
Group=redis
LimitNOFILE=100000
ExecStart=/usr/local/redis/bin/redis-server /usr/local/redis/etc/sentinel.conf --sentinel
ExecStop=/usr/local/redis/bin/redis-cli -p 26379 shutdown
Restart=on-failure
[Install]
WantedBy=multi-user.target

启动脚本,查看状态

复制代码
systemctl start sentienl

redis-cli -redis-cli -a 123456 info replication

[root@node37 redis]# redis-cli -a 123456 -p 26379 -h 192.168.37.17  info sentinel
# Sentinel
sentinel_masters:1
sentinel_tilt:0
sentinel_running_scripts:0
sentinel_scripts_queue_length:0
sentinel_simulate_failure_flags:0
master0:name=mymaster,status=ok,address=192.168.37.17:6379,slaves=2,sentinels=3
相关推荐
摇滚侠1 小时前
阿里云安装的 Redis 在什么位置,如何找到 Redis 的安装位置
redis·阿里云·云计算
啦啦啦_99991 小时前
Redis-2-queryFormat()方法
数据库·redis·缓存
forestsea4 小时前
深入理解Redisson RLocalCachedMap:本地缓存过期策略全解析
redis·缓存·redisson
佛祖让我来巡山4 小时前
Redis 为什么这么快?——「极速快递站」的故事
redis·redis为什么快?
Volunteer Technology4 小时前
sentinel基本操作
spring cloud·sentinel
啦啦啦_99996 小时前
Redis-0-业务逻辑
数据库·redis·缓存
自不量力的A同学6 小时前
Redisson 4.2.0 发布,官方推荐的 Redis 客户端
数据库·redis·缓存
fengxin_rou6 小时前
[Redis从零到精通|第四篇]:缓存穿透、雪崩、击穿
java·redis·缓存·mybatis·idea·多线程
程序员泠零澪回家种桔子7 小时前
Sentinel核心能力解析:限流与集群方案
后端·架构·sentinel
是阿楷啊7 小时前
Java大厂面试场景:音视频场景中的Spring Boot与微服务实战
spring boot·redis·spring cloud·微服务·grafana·prometheus·java面试