借助heartbeat构建redis的主备高可用集群示例

假设master的ip是192.168.193.240,slave的ip是192.168.193.239,虚拟ip是192.168.193.230
安装介质位置:/home/software/redis-2.6.6.tar.gz
要实现的机制是:redis一主一备,主机可读写,备机只读,客户端通过访问230这个虚拟IP来操作redis。
当备机宕机重启后,会自动恢复为redis备机,并同步主机数据。
当主机宕机重启后,原备机自动接管成为主机,原主机重启后成为备机30秒,从原备机同步数据,30秒后,原主机恢复为主机,原备机恢复为备机。
在redis使用频率很高的时候,主机宕机的一段时间内,可能有大量数据写入原备机,30秒同步时间未必足够,建议通过测试确定同步的时间。
下面出现的jeremiahxu.com是假设的密码。

1. 安装redis
# cd /home/software
# tar -zxvf redis-2.6.6.tar.gz
# mv /home/software/redis-2.6.6 /opt/redis
# cd /opt/redis
# make && make install

2. 修改配置文件
# vi /opt/redis/redis.conf
经常需要修改的参数包括:
daemonize yes 
yes表示后台运行redis
loglevel debug 
日志级别改成debug是用于开发和测试环境,生产环境建议还是换成notice或者warning级别。
logfile /var/log/redis.log 
指定日志文件
databases 1 
database的数量,默认是16,但是我只需要一个。
requirepass jeremiahxu.com
master的密码,slaver需要这个密码才能和master相连(客户端连接时也需要密码),主要是出于安全性考虑,如果你的网络环境比较“干净”,
那么就不需要设置密码了,因为redis多数情况是部署在内网的,外网无法访问。
masterauth jeremiahxu.com
slave连接master时用到的密码。
在备机上增加如下配置(主机不需要这句):
slaveof 192.168.193.240

3. 启动停止命令
启动:redis-server
指定配置文件的启动:/opt/redis/src/redis-server /opt/redis/redis.conf
停止:redis-cli shutdown
指定端口停止(没有使用默认端口启动时):redis-cli -p 6380 shutdown
如果使用了密码:redis-cli -a jeremiahxu.com shutdown
BTW:启动redis时要指定配置文件,不指定配置文件的话,redis并没有加载你安装好看到的那个默认的redis.conf,所以你修改了那个redis.conf而启动时不指定它的话,是没有用的。

4.配置成服务
vi /etc/init.d/redis
=======================================================
#!/bin/bash
#
# Startup script for the redis
#
# chkconfig: 345 80 15
# description: redis
# Source function library.p
. /etc/rc.d/init.d/functions
export REDIS_HOME=/opt/redis
case "$1" in
start)
$REDIS_HOME/src/redis-server $REDIS_HOME/redis.conf
;;
stop)
$REDIS_HOME/src/redis-cli -a jeremiahxu.com shutdown
;;
restart)
$REDIS_HOME/src/redis-cli -a jeremiahxu.com shutdown
$REDIS_HOME/src/redis-server $REDIS_HOME/redis.conf
;;
status)
$REDIS_HOME/src/redis-server -v
;;
*)
echo "Usage: $0 {start|stop|restart|status}"
esac
exit 0
=======================================================
别忘记增加执行权限:
chmod +x /etc/init.d/redis

5. 安装配置heartbeat
yum -y install heartbeat
heartbeat有三个配置文件:ha.cf、authkeys、haresources
vi /etc/ha.d/authkeys
===============================
auth 1
1 crc
===============================
authkeys这个文件必须设置只读权限
chmod 600 /etc/ha.d/authkeys

vi /etc/ha.d/ha.cf
================================================
logfile /var/log/ha-log
logfacility local0
keepalive 1
deadtime 10
warntime 4
initdead 120
udpport 6940
ucast eth0 192.168.193.239 6940
auto_failback on
node centos-a
node centos-b
================================================
ha.cf这个配置文件的ucast参数,后面的ip地址要写双机集群中对方的ip和端口。
udpport参数最好改掉,我这里改成了6940,默认的694端口很可能会被rcp占用。

vi /etc/ha.d/haresources
==================================================================
centos-a IPaddr::192.168.193.230/24 redis-cluster
==================================================================
这个配置文件主备是一样的,包括前面那个值:centos-a,这个是主服务器的名字。

接着配置自动切换脚本:
vi /etc/ha.d/resource.d/redis-cluster
在主机上:
==================================================================
#!/bin/bash
#
# Startup script for the redis cluster
#
# chkconfig: 345 80 15
# description: redis cluster
# Source function library.p
. /etc/rc.d/init.d/functions
export REDIS_HOME=/opt/redis
case "$1" in
start)
$REDIS_HOME/src/redis-cli -a jeremiahxu.com slaveof 192.168.193.239 6379
sleep 30
$REDIS_HOME/src/redis-cli -a jeremiahxu.com slaveof NO ONE
;;
stop)
$REDIS_HOME/src/redis-cli -a jeremiahxu.com slaveof 192.168.193.239 6379
;;
esac
exit 0
==================================================================
在备机上:
==================================================================
#!/bin/bash
#
# Startup script for the redis cluster
#
# chkconfig: 345 80 15
# description: redis cluster
# Source function library.p
. /etc/rc.d/init.d/functions
export REDIS_HOME=/opt/redis
case "$1" in
start)
$REDIS_HOME/src/redis-cli -a jeremiahxu.com slaveof NO ONE
;;
stop)
sleep 30 && $REDIS_HOME/src/redis-cli -a jeremiahxu.com slaveof 192.168.193.240 6379 &
;;
esac
exit 0
==================================================================
redis-cluster是我自定义的切换脚本,名字其实是可以随便起的,但必须放到/etc/ha.d/resource.d/目录下或者/etc/init.d/目录,并且要赋予执行权限。



猜你喜欢

转载自surelei.iteye.com/blog/1766089
今日推荐