`
surelei
  • 浏览: 67888 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

借助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/目录,并且要赋予执行权限。



1
4
分享到:
评论

相关推荐

    高可用MySQL_构建健壮的数据中心_第2版

    《高可用MySQL_构建健壮的数据中心_第2版》这本书深入探讨了如何在实际环境中构建和维护高可用性的MySQL数据库系统。MySQL是全球最受欢迎的开源关系型数据库管理系统之一,其高可用性对于企业的业务连续性和数据安全...

    zookeeper高可用shell脚本监测.

    在高可用Redis集群中,Zookeeper作为一个中心化的仲裁者,负责监控Redis节点的状态,确保数据的一致性和完整性。当Redis主节点发生故障时,Zookeeper能够快速检测到并触发故障转移,将从节点提升为主节点,从而避免...

    ELK使用教程

    Kafka 是另一种流行的中间件,用于高吞吐量的数据流处理,Logstash 可以与 Kafka 结合使用。 ##### Beats **Filebeat** Filebeat 是一种轻量级的日志转发器,适合用于收集服务器上的文件日志。 **Packetbeat ...

    Elastic Stack 技术指南

    性能与测试章节介绍了如何利用不同的监控方案,例如generator方式、logstash-input-heartbeat方式、jmx启动参数方式、API方式等,以及通过redis和kafka进行数据传输。此外,还讲解了如何通过Elasticsearch的架构原理...

    ELKstack 中文指南

    指南中通过入门示例引导读者学习Logstash的安装、插件安装、长期运行插件配置、input插件配置(包括collectd、file、stdin、syslog、tcp、json等多种方式)、codec配置、filter配置以及output配置(如elasticsearch...

    基于Lua的upstream管理和健康检查模块Lua-Resty-Checkups.zip

    特点:支持周期性upstream服务管理操作支持管理和健康检查支持upstream动态更新有利于加权轮询或哈希平衡支持 Nginx C upstream同步操作可使用级别和键值实现集群使用简介:-- config.lua _M = {} _M.global ...

Global site tag (gtag.js) - Google Analytics