设为首页 收藏本站
查看: 743|回复: 0

[经验分享] redis主从+sentinel

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-4-29 08:41:01 | 显示全部楼层 |阅读模式
redis作为nosql数据库主流产品之一,现在被广泛使用,如何保证redis的高可用和故障自动切换,本文介绍了redis的主从配置方法,及故障切换的sentinel搭建。如下:
环境说明:
server 系统:CentOS 6.5 X64
redis软件说明:2.8.19版本
一:配置主从redis
1、架构:
主库:172.16.52.130
从库1:172.16.52.131
从库2:172.16.52.132
2、主从操作:
tar xvf redis-2.8.19.tar.gz -C /usr/local
cd /usr/local/redis-2.8.19/

make && make install

mkdir data
vim redis.conf       

---
#在最后可以直接加如下命令
aof-rewrite-incremental-fsync yes
daemonize yes
logfile /var/log/redis.log
syslog-enabled no
dir /usr/local/redis-2.8.19/data
requirepass system                                #为下面sentinel做准备主从均需配置

slaveof 172.16.52.130 6379                #从库加上该配置,主库不加该配置
masterauth system                                #为下面sentinel做准备主从均需配置
#以上设计到的密码必须相同,若设置则都设置,否则都不设置
---
3、数据库启停操作
启动:redis-server /usr/local/redis/redis.conf
关闭:redis-cli -a system shutdown
notes:
1)master可以不设置登陆密码,则slave不用设置masterauth
2)master不设置登陆密码时,关闭命令为:redis-cli shutdown
4.测试
redis-cli -a system
info
---
slave0:ip=172.16.52.131,port=6379,state=online,offset=211171,lag=0
slave1:ip=172.16.52.130,port=6379,state=online,offset=211171,lag=1
---
同时可以进行数据测试:在主库上建立插入数据,看从库是否同步。
二、配置sentinel
vim /etc/sentinel.conf

---
port 26379
daemonize yes
logfile "/var/log/sentinel.log"
sentinel monitor mymaster 172.16.52.132 6379 1
sentinel down-after-milliseconds mymaster 3000
sentinel failover-timeout mymaster 10000
sentinel auth-pass mymaster system                        #本验证密码和上面主从密码保持一致,若主从没有设置验证密码,则不需要配置本条
---
启停sentinel
redis-sentinel /etc/sentinel.conf
redis-cli -p 26379 shutdown
日志查看:
tail -f /var/log/sentinel.log
[24259] 27 Apr 16:42:58.280 # Sentinel runid is f6688a7526b2b5f3298dc0c5348ae78207f1c1be
[24259] 27 Apr 16:42:58.280 # +monitor master mymaster 172.16.52.130 6379 quorum 1
[24259] 27 Apr 16:42:58.280 * +slave slave 172.16.52.132:6379 172.16.52.132 6379 @ mymaster 172.16
.52.130 6379
[24259] 27 Apr 16:42:58.280 * +slave slave 172.16.52.131:6379 172.16.52.131 6379 @ mymaster 172.16
.52.130 6379
为保证redis高可用,使得sentinel有意义,至少选择两台及其以上sentinel,一般建议最好三台,以确保投票机制


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-61715-1-1.html 上篇帖子: redis 简介与常用操作 下篇帖子: Redis高可用方案(redis主从+keepalived+sentinel)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表