天天看点

3台服务器Redis高可用哨兵模式

<a href="https://s3.51cto.com/wyfs02/M00/94/CC/wKioL1kODgGTTvlLAAATD0jCZmI995.png" target="_blank"></a>

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

监控(Monitoring): Sentinel 会不断地检查你的主服务器和从服务器是否运作正常。 

提醒(Notification): 当被监控的某个 Redis 服务器出现问题时, Sentinel 可以通过 API 向管理员或者其他应用程序发送通知。 

自动故障迁移(Automatic failover): 当一个主服务器不能正常工作时, Sentinel 会开始一次自动故障迁移操作, 它会将失效主服务器的其中一个从服务器升级为新的主服务器, 并让失效主服务器的其他从服务器改为复制新的主服务器; 当客户端试图连接失效的主服务器时, 集群也会向客户端返回新主服务器的地址, 使得集群可以使用新主服务器代替失效服务器。 

Redis Sentinel 是一个分布式系统, 你可以在一个架构中运行多个 Sentinel 进程(progress), 这些进程使用流言协议(gossip protocols)来接收关于主服务器是否下线的信息, 并使用投票协议(agreement protocols)来决定是否执行自动故障迁移, 以及选择哪个从服务器作为新的主服务器。 

虽然 Redis Sentinel 释出为一个单独的可执行文件 redis-sentinel , 但实际上它只是一个运行在特殊模式下的 Redis 服务器, 你可以在启动一个普通 Redis 服务器时通过给定 –sentinel 选项来启动 Redis Sentinel 。

环境 

CentOS7.2 

redis3.2.8

服务器IP

redis端口

哨兵端口

服务器角色

10.1.0.160

6379

26379

10.1.0.161

从1

10.1.0.71

从2

以下是单redis安装脚本,可适用于单redis使用。 

<code>cat install_redis.sh</code>

redis启停脚本示例: 

<code>cat redis-server</code>

redis-sentinel启停脚本示例:

3台主机相同设置:

按照前面单redis安装方法安装程序;

创建相应数据目录;

<code>vim redis.conf</code>

群集文件配置 

<code>vim sentinel.conf</code>

相对主redis配置,多添加了如下行:

vim sentinel.conf

启动redis,主从都要启动 

<code>/usr/local/redis/sbin/redis-server start</code> 

启动群集监控,主从都要启动 

<code>/usr/local/redis/sbin/redis-sentinel start</code>

启动报错处理

故障切换机制

启动群集之后,群集程序默认会在主从的sentinel.conf文件中加入群集信息

主:

从1:

从2:

模拟主故障

从哨兵配置文件中可以看到当前的主库的已经发生了改变

redis的哨兵端口26379使用redis-cli可以连接查看哨兵相关信息,要想连接此高可用redis,可使用官方的连接客户端。使用哨兵监控当主故障后会自动切换从为主,当主启动后就变成了从。至少要3哨兵和3redis节点才能允许挂一节点还能保证服务可用性。

本文转自 ygqygq2 51CTO博客,原文链接:http://blog.51cto.com/ygqygq2/1922780,如需转载请自行联系原作者