注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

逍遥子 曰:

得失失得 何必患得患失 舍得得舍 不妨不舍不得

 
 
 

日志

 
 

[转]通过Keepalived实现Redis Failover自动故障切换功能  

2014-06-09 11:29:24|  分类: redis |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

参考资料:

http://patrick-tang.blogspot.com/2012/06/redis-keepalived-failover-system.html

http://deidara.blog.51cto.com/400447/302402

目前,Redis还没有一个类似于MySQL Proxy或Oracle RAC的官方HA方案。
Redis作者有一个名为Redis Sentinel的计划(http://redis.io/topics/sentinel),据称将会有监控,报警和自动故障转移三大功能,非常不错。
但可惜的是短期内恐怕还不能开发完成。

因此,如何在出现故障时自动转移是一个需要解决的问题。

通过对网上一些资料的搜索,有建议采用HAProxy或Keepalived来实现的,事实上如果是做Failover而非负载均衡的话,Keepalived的效率肯定是超过HAProxy的,所以我决定采用Keepalived的方案。

环境介绍:
Master: 10.6.1.143
Slave: 10.6.1.144
Virtural IP Address (VIP): 10.6.1.200

设计思路:
当 Master 与 Slave 均运作正常时, Master负责服务,Slave负责Standby;
当 Master 挂掉,Slave 正常时, Slave接管服务,同时关闭主从复制功能;
当 Master 恢复正常,则从Slave同步数据,同步数据之后关闭主从复制功能,恢复Master身份,于此同时Slave等待Master同步数据完成之后,恢复Slave身份。
然后依次循环。

需要注意的是,这样做需要在Master与Slave上都开启本地化策略,否则在互相自动切换的过程中,未开启本地化的一方会将另一方的数据清空,造成数据完全丢失。

下面,是具体的实施步骤:

在Master和Slave上安装Keepalived
$ sudo apt-get install keepalived

修改Master和Slave的/etc/hosts文件
$ sudo vim /etc/hosts

1127.0.0.1   localhost
210.6.1.143  redis
310.6.1.144  redis-slave

默认安装完成keepalived之后是没有配置文件的,因此我们需要手动创建:

首先,在Master上创建如下配置文件:
$ sudo vim /etc/keepalived/keepalived.conf

01vrrp_script chk_redis {
02                script "/etc/keepalived/scripts/redis_check.sh"   ###监控脚本
03                interval 2                                        ###监控时间
04}
05vrrp_instance VI_1 {
06        state MASTER                            ###设置为MASTER
07        interface eth0                          ###监控网卡   
08        virtual_router_id 51
09        priority 101                            ###权重值
10        authentication {
11                     auth_type PASS             ###加密
12                     auth_pass redis            ###密码
13        }
14        track_script {
15                chk_redis                       ###执行上面定义的chk_redis
16        }
17        virtual_ipaddress {
18             10.6.1.200                         ###VIP
19        }
20        notify_master /etc/keepalived/scripts/redis_master.sh
21        notify_backup /etc/keepalived/scripts/redis_backup.sh
22        notify_fault  /etc/keepalived/scripts/redis_fault.sh
23        notify_stop   /etc/keepalived/scripts/redis_stop.sh
24}

然后,在Slave上创建如下配置文件:
$ sudo vim /etc/keepalived/keepalived.conf

01vrrp_script chk_redis {
02                script "/etc/keepalived/scripts/redis_check.sh"   ###监控脚本
03                interval 2                                        ###监控时间
04}
05vrrp_instance VI_1 {
06        state BACKUP                                ###设置为BACKUP
07        interface eth0                              ###监控网卡
08        virtual_router_id 51
09        priority 100                                ###比MASTRE权重值低
10        authentication {
11                     auth_type PASS
12                     auth_pass redis                ###密码与MASTRE相同
13        }
14        track_script {
15                chk_redis                       ###执行上面定义的chk_redis
16        }
17        virtual_ipaddress {
18             10.6.1.200                         ###VIP
19        }
20        notify_master /etc/keepalived/scripts/redis_master.sh
21        notify_backup /etc/keepalived/scripts/redis_backup.sh
22        notify_fault  /etc/keepalived/scripts/redis_fault.sh
23        notify_stop   /etc/keepalived/scripts/redis_stop.sh
24}

在Master和Slave上创建监控Redis的脚本
$ sudo mkdir /etc/keepalived/scripts
$ sudo vim /etc/keepalived/scripts/redis_check.sh

01#!/bin/bash
02 
03ALIVE=`/opt/redis/bin/redis-cli PING`
04if "$ALIVE" == "PONG" ]; then
05  echo $ALIVE
06  exit 0
07else
08  echo $ALIVE
09  exit 1
10fi


  评论这张
 
阅读(710)| 评论(0)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017