配置哨兵监控Redis运行情况
Redis的主从架构,如果master发现故障了,还得手动将slave切换成master继续服务,手动的方式容易造成失误,导致数据丢失,那Redis有没有一种机制可以在master和slave进行监控,并在master发送故障的时候,能自动将slave切换成master呢?有的,那就是哨兵。
哨兵的作用:
1、监控redis进行状态,包括master和slave
2、当master down机,能自动将slave切换成master

下面配置哨兵监控redis进程,假如我们已经配置好了Master和Slave,具体详细配置参考 http://www.cnblogs.com/liuyansheng/p/6530851.html
1、新建配置文件,命名为sentinel.conf,输入下面内容
sentinel monitor mymaster 192.168.137.101
sentinel auth-pass myMaster master123 #配置密码
mymaster :master服务的名称,随便定义
192.168.137.101 6379:master的ip和端口
1:在至少1个哨兵实例都认为master down后把master标记为odown(objective down客观down;相对应的存在sdown,subjective down,主观down)状态
sentinel.conf具体配置参考 http://www.cnblogs.com/liuyansheng/p/6531321.html
2、启动哨兵,在redis的src目录下,执行下面命令
./redis-sentinel ../../conf/sentinel.conf

可以看到哨兵已经把master和slave都监控了。
3、进行哨兵测试,将103的slave进行shutdown,哨兵将监控到状态。
:X Jun ::26.647 # +sdown slave 192.168.137.102: 192.168.137.103 @ myMaster 192.168.137.101
然后将103重启服务,查看哨兵控制台
:X Jun ::22.716 * +reboot slave 192.168.137.102: 192.168.137.103 @ myMaster 192.168.137.101
已经进行恢复
4、将master kill掉,查看哨兵后台打印信息
:X Jun ::50.300 # +sdown master myMaster 192.168.137.101 #说明master服务已经宕机
:X Jun ::50.300 # +odown master myMaster 192.168.137.101 #quorum /
:X Jun ::50.300 # +new-epoch
:X Jun ::50.300 # +try-failover master myMaster 192.168.137.101 #开始恢复
:X Jun ::50.304 # +vote-for-leader a496627d72d98fde98b8270e297ab32b330ebac7 #投票选举哨兵leader,现在就一个哨兵所以leader就自己
:X Jun ::50.304 # +elected-leader master myMaster 192.168.137.101 # 选中leader
:X Jun ::50.304 # +failover-state-select-slave master myMaster 192.168.137.101 #选择master
:X Jun ::50.357 # +selected-slave slave 192.168.137.102: 192.168.137.102 @ myMaster 192.168.137.101 #选中192.168.137. 6379作为切换
:X Jun ::50.357 * +failover-state-send-slaveof-noone slave 192.168.137.102: 192.168.137.102 @ myMaster 192.168.137.101 #发送slaveof no one命令
:X Jun ::50.420 * +failover-state-wait-promotion slave 192.168.137.102: 192.168.137.102 @ myMaster 192.168.137.101 #等待升级master
:X Jun ::50.515 # +promoted-slave slave 192.168.137.102: 192.168.137.102 @ myMaster 192.168.137.101 #192.168.137.102 6379升级为master
:X Jun ::50.515 # +failover-state-reconf-slaves master myMaster 192.168.137.101
:X Jun ::50.566 * +slave-reconf-sent slave 192.168.137.103: 192.168.137.103 @ myMaster 192.168.137.101
:X Jun ::51.333 * +slave-reconf-inprog slave 192.168.137.103: 192.168.137.103 @ myMaster 192.168.137.101
:X Jun ::52.382 * +slave-reconf-done slave 192.168.137.103: 192.168.137.103 @ myMaster 192.168.137.101
:X Jun ::52.438 # +failover-end master myMaster 192.168.137.101 #故障恢复完成
:X Jun ::52.438 # +switch-master myMaster 192.168.137.101 192.168.137.102 #master切换
:X Jun ::52.438 * +slave slave 192.168.137.103: 192.168.137.103 @ myMaster 192.168.137.102 #添加master从库
:X Jun ::52.438 * +slave slave 192.168.137.101: 192.168.137.101 @ myMaster 192.168.137.102 #添加master从库
:X Jun ::22.463 # +sdown slave 192.168.137.101: 192.168.137.101 @ myMaster 192.168.137.102 #发现192.168.137. 6379故障
5、配置多个哨兵,修改配置文件
sentinel monitor myMaster1 192.168.137.101
sentinel monitor myMaster2 192.168.137.101
sentinel monitor myMaster3 192.168.137.101 sentinel auth-pass myMaster1 master123
sentinel auth-pass myMaster2 master123
sentinel auth-pass myMaster3 master123
这里是配置3个哨兵,架构如下:

配置哨兵监控Redis运行情况的更多相关文章
- zabbix监控redis连接情况
配置zabbix客户端配置文件 vim /etc/zabbix/zabbix_agentd.conf 添加 Include=/etc/zabbix/zabbix_agentd.d/ 添加脚本对red ...
- 使用Zabbix官方模板监控Redis运行状况
运行环境: OS:CentOS 6.8 / Python: 2.6.6 / Pip: 7.1.0 / Redis:3.0 / Zabbix:3.0.3 Zabbix官方提供的监控模板. 项目地址:ht ...
- SpringMVC4+MyBatis+SQL Server2014+druid 监控SQL运行情况
前言 在基于SpringMVC+MyBatis的开发过程中,我们希望能看到自己手写SQL的执行情况,在开发阶段我们可以配置log4j在控制台里基于debug模式查看,那么上线后,在生产声我们想查看SQ ...
- Replication--修改复制代理配置来查看代理运行情况
1>在复制监视器中选中订阅右键 2>选择代理配置文件 3>将代理配置文件设置为”详细历史记录代理配置文件“,确定以保存 4>重启代理 5>代理运行一段时间后,重启代理 6 ...
- 使用jvisualvm工具来监控java运行情况
jvisualvm是jdk自带的工具.所以要先安装jdk 1.jvisualvm工具的路径: 通过which jvisualvm来查看 /usr/local/jdk1.7.0_79/bin/jvi ...
- 使用jconsole工具来监控java运行情况
参考:http://blog.163.com/lucas_nina/blog/static/185960149201493034258448/ 经验证OK jconsole是jdk自带的工具. ...
- jconsole工具监控java运行情况
jconsole是jdk自带的工具.所以要先安装jdk 1.jconsole工具的路径: 通过which jconsole来查看 /usr/local/jdk1.7.0_79/bin/jconsol ...
- 在Centos中部署redis运行状态图形化监控工具 — RedisLive
写在前面 前两天看到张善友老师的一篇文章<先定个小目标, 使用C# 开发的千万级应用>,里面给出了一张腾讯OA基础服务中redis运行情况的一张监控图,然后想到自己的项目中前不久也上了re ...
- redis运行状态图形化监控工具 — RedisLive
在Centos中部署redis运行状态图形化监控工具 — RedisLive 写在前面 前两天看到张善友老师的一篇文章<先定个小目标, 使用C# 开发的千万级应用>,里面给出了一张腾讯 ...
随机推荐
- Cocos2d-x 3.0final 终结者系列教程15-win7+vs2012+adt+ndk环境搭建(无Cygwin)
最终不用Cygwin 了.非常高兴 为什么要用Win7? 由于VS2012要求Win7以上系统才干安装! 为什么要用vs2012? 由于VS2012才支持C++11! 为什么要支持C++11? 由于C ...
- Regex 手机号 座机 正則表達式
近期在工作中须要推断一个号码是否是手机号,是否是座机号. 在网上也搜到了大家总结的方法,没有直接使用这些方法是由于:手机号码在不断開始新的号码段(比方17x).座机号中个别区号由于行政区域的变化而废除 ...
- Mysql启动自己主动设置max_connections为其它值
背景 有同学反应.产品连不上,登陆到server.发现连接数不够了. 接着先重新启动mysql,发如今mysql启动的时候会报Waring Warning Changed limits: max_op ...
- BZOJ 2818 Gcd 线性欧拉
题意:链接 方法:线性欧拉 解析: 首先列一下表达式 gcd(x,y)=z(z是素数而且x,y<=n). 然后我们能够得到什么呢? gcd(x/z,y/z)=1; 最好还是令y>=x 则能 ...
- maven的坑2
导入工程后,pom.xml文件中以下插件报错: <plugin> <groupId>com.jayway.maven.plugins.android.generation2&l ...
- 文件共享和使用 dup 函数创建新描述符的区别
前言 文件共享是指同时打开一个文件 用 dup 函数能对指定文件描述符再创建一个新的描述符,且这个新的描述符和旧的描述符指向的是同一个文件. 这两种行为有什么区别呢?下面给出的两张文件系统的图形象的解 ...
- 模式识别之不变矩---SIFT和SURF的比较
- Drupal 初次使用感受,兴许补充。
非常久曾经就接触过.下载下来安装,结果界面太丑,太难看,直接删除. 近期又一次想到开源CMS,好奇看到那么多人推崇drupal.也便下载来又一次研究了下. 刚接触了下.只是总体使用感觉非常差.尤其几个 ...
- Hybrid--WebView中使用Ajax
Hybrid框架下的app,使用的Ajax.须要注意的是UIWebViewDelegate不会监測到Ajax的request.也就是再运行Ajax代码时.shouldStartLoadWithReuq ...
- 2016/07/07 apmserv5.2.6 Apache启动失败,请检查相关配置。MySQL5.1已启动。
因为要用PHP做一个程序,在本机上配PHP环境,下了个APMServ5.26,安装很简单,不再多说,装好后,启动,提示错误,具体是:“Apache启动失败,请检查相关配置.√MySQL5.1已启动”, ...