什么是redis sentinel

参考文档:https://redis.io/topics/sentinel

简单的来说,就是Redis Sentinel 为redis 提供高可用性,主要体现在下面几个方面:
1.监控:redis sentinel会不间断的监控主服务器和从服务器是否正常工作
2.通知:当出现问题时,sentinel可以通过API通知系统管理员以及另外的服务器
3.自动故障转移:如果主服务器出现故障,sentinel可以启动故障转移,将其中一台从服务器升级为主服务器,其他的从服务器会重新配置为新主服务器 4.提供配置:sentinel充当客户端发现权限来源,客户端连接到sentinel询问负责给定服务器当前redis主服务器地址,如果发生故障,sentinel将报告新地址

redis sentinel 模拟环境

模拟环境为:1主2从

========redis=================sentinel==========

master:127.0.0.1 6379       127.0.0.1 26379
slave1:127.0.0.1 6380       127.0.0.1 26380
slave2:127.0.0.1 6381       127.0.0.1 26381

环境搭建

redis.conf配置

6379

# .conf | grep -Ev "^$|^#"
bind 127.0.0.1
port
daemonize yes
pidfile /var/run/redis_6379.pid
logfile "/root/redis/redis-6379.log"
dbfilename dump-.rdb
dir /root/redis
...
#

6380

# .conf | grep -Ev "^$|^#"
bind 127.0.0.1
port
daemonize yes
pidfile /var/run/redis_6380.pid
logfile "/root/redis/redis-6380.log"
dbfilename dump-.rdb
dir /root/redis
...
#

6381

# .conf | grep -Ev "^$|^#"
bind 127.0.0.1
port
daemonize yes
pidfile /var/run/redis_6381.pid
logfile "/root/redis/redis-6381.log"
dbfilename dump-.rdb
dir /root/redis
...
#

sentinel.conf配置

6379/6380/6381

# cat sentinel-*.conf | grep -Ev "^#|^$"
port
daemonize yes
logfile "/root/redis/sentinel-6379.log"
dir "/tmp"
sentinel monitor mymaster
sentinel down-after-milliseconds mymaster
sentinel parallel-syncs mymaster
sentinel failover-timeout mymaster
#

启动redis server 和 sentinel

redis:
# redis-server /etc/redis_6379.conf
# redis-server /etc/redis_6380.conf
# redis-server /etc/redis_6381.conf

sentinel:
# redis-sentinel /etc/sentinel-.conf
# redis-sentinel /etc/sentinel-.conf
# redis-sentinel /etc/sentinel-.conf

配置主从复制

# redis-cli -p
> SLAVEOF
OK
> exit

# redis-cli -p
> SLAVEOF
OK
> exit

模拟故障迁移

首先,kill 掉redis master进程

#  |  $n  ;done;

分析log

首先,redis 从服务器首先发现redis master 服务器无法连接,报错如下:
# *.log
==> redis-.log <==
:S  Nov ::54.235 # Connection with master lost.
:S  Nov ::54.235 * Caching the disconnected master state.

==> redis-.log <==
:S  Nov ::
:S  Nov ::54.466 * MASTER <-> SLAVE sync started
:S  Nov ::54.467 # Error condition on socket for SYNC: Connection refused

==> redis-.log <==
:S  Nov ::
:S  Nov ::54.782 * MASTER <-> SLAVE sync started
:S  Nov ::54.782 # Error condition on socket for SYNC: Connection refused
...
紧接着,redis sentinel 完成故障切换,从log来看,当6379主节点挂了之后,redis重新提了一个从节点6380为主节点,log 如下:
# *.log
==> sentinel-.log <==
:X  Nov ::

==> sentinel-.log <==
:X  Nov ::

==> sentinel-.log <==
:X  Nov ::

==> sentinel-.log <==
:X  Nov :: #quorum /
:X  Nov ::
:X  Nov ::

==> sentinel-.log <==
:X  Nov :: #quorum /
:X  Nov ::
:X  Nov ::

==> sentinel-.log <==
:X  Nov ::

==> sentinel-.log <==
:X  Nov ::

==> sentinel-.log <==
:X  Nov ::

==> sentinel-.log <==
:X  Nov ::

==> sentinel-.log <==
:X  Nov ::
:X  Nov ::

==> sentinel-.log <==
:X  Nov ::

==> sentinel-.log <==
:X  Nov ::

==> sentinel-.log <==
:X  Nov ::
:X  Nov ::
:X  Nov ::  @ mymaster
:X  Nov ::  @ mymaster
:X  Nov ::  @ mymaster
:X  Nov ::  @ mymaster
:X  Nov ::
:X  Nov ::  @ mymaster 

==> sentinel-.log <==
:X  Nov :: @ mymaster
:X  Nov ::
:X  Nov ::  @ mymaster
:X  Nov ::  @ mymaster 

==> sentinel-.log <==
:X  Nov :: @ mymaster
:X  Nov ::
:X  Nov ::  @ mymaster
:X  Nov ::  @ mymaster 

==> sentinel-.log <==
:X  Nov ::
:X  Nov ::  @ mymaster
:X  Nov ::  @ mymaster
:X  Nov ::
:X  Nov ::
:X  Nov ::  @ mymaster
:X  Nov ::  @ mymaster 

==> sentinel-.log <==
:X  Nov ::  @ mymaster 

==> sentinel-.log <==
:X  Nov ::  @ mymaster 

==> sentinel-.log <==
:X  Nov ::  @ mymaster 
再返回过来看redis server的log,此时可以看到6381为从节点已经向主节点6380请求并且完成了复制操作
==> redis-.log <==
:M  Nov :: asks for synchronization
:M  Nov :: accepted. Sending  bytes of backlog starting from offset .

==> redis-.log <==
:S  Nov ::25.823 * Successful partial resynchronization with master.
:S  Nov ::25.823 # Master replication ID changed to 0288d040464ebccbb56dc56d54455434a406bcb2
:S  Nov ::25.823 * MASTER <-> SLAVE sync: Master accepted a Partial Resynchronization.

当我们再启动6379服务器时,sentinel会让6379成为从库并且连接6380服务器,log如下: 

启动6379服务器
# redis-server /root/redis/redis-.conf

# *.log
...
==> sentinel-.log <==
:X  Nov ::  @ mymaster
...

# *.log
...
==> redis-.log <==
:S  Nov :: bytes from master
:S  Nov ::00.566 * MASTER <-> SLAVE sync: Flushing old data
:S  Nov ::00.566 * MASTER <-> SLAVE sync: Loading DB in memory
:S  Nov ::00.566 * MASTER <-> SLAVE sync: Finished with success

==> redis-.log <==
:S  Nov :: changes  seconds. Saving...
:S  Nov ::
:C  Nov ::36.486 * DB saved on disk
:C  Nov :: MB of memory used by copy-on-write
:S  Nov ::36.569 * Background saving terminated with success
...

未完待续。。。

Redis Sentinel 模拟故障迁移的更多相关文章

  1. Redis(九)哨兵:Redis Sentinel

    Redis的主从复制模式下,一旦主节点由于故障不能提供服务,需要人工将从节点晋升为主节点,同时还要通知应用方更新主节点地址,对于很多应用场景这种故障处理的方式是无法接受的. Redis从2.8开始正式 ...

  2. Redis源码阅读(六)集群-故障迁移(下)

    Redis源码阅读(六)集群-故障迁移(下) 最近私人的事情比较多,没有抽出时间来整理博客.书接上文,上一篇里总结了Redis故障迁移的几个关键点,以及Redis中故障检测的实现.本篇主要介绍集群检测 ...

  3. Redis源码阅读(五)集群-故障迁移(上)

    Redis源码阅读(五)集群-故障迁移(上) 故障迁移是集群非常重要的功能:直白的说就是在集群中部分节点失效时,能将失效节点负责的键值对迁移到其他节点上,从而保证整个集群系统在部分节点失效后没有丢失数 ...

  4. Redis Sentinel高可用配置及C#访问

    本文环境如下: 操作系统:ubuntu-14.04.1-desktop-amd64 Redis:2.8.19 如果使用虚拟机则将每台的网络设置为桥接,否则他们之间能连上,局域网连不上. 系统设计如图: ...

  5. Redis的同步(主从复制)和Redis Sentinel

    Redis的同步可以让其他服务器拥有一个不断更新的数据副本,从而使拥有数据副本的服务器可以处理客户端发出的读请求. 1.Redis同步的方法: 我们可以通过发送SLAVEOF host port命令来 ...

  6. Redis sentinel 哨兵模式集群方案配置

    第一个方案是创建 redis cluster,第二种方案就是用哨兵模式来进行主从替换以及故障恢复.兵模式集群方案配置 一.sentinel介绍 Sentinel作用: 1):Master状态检测 2) ...

  7. Redis Sentinel配置小记

    Sentinel是一个管理多个redis实例的工具,它可以实现对redis的监控.通知.自动故障转移.sentinel不断的检测redis实例是否可以正常工作,通过API向其他程序报告redis的状态 ...

  8. Redis Sentinel 高可用服务搭建

    阅读目录: 关于 Redis 的概念 关于 Redis Sentinel 的概念 搭建 Redis Server(master) 搭建 Redis Server(slave) 搭建 Redis Sen ...

  9. Redis sentinel & cluster 原理分析

    1. Redis集群实现分析 1.1  sentinel 1.   功能 Sentinel实现如下功能: (1)monitoring--redis实例是否正常运行. (2)notification-- ...

随机推荐

  1. 【机器学习_7】numpy

    1. 定义 入门选手不抄作业了,先简单理解下,numpy最大的应用大概是方便做数学运算啥的,功劳在于一个叫ndarray(多维数组)的数据类型.numpy本身没有强大分析能力,只是pandas的基础啥 ...

  2. 第三方jar上传到Maven私服(Nexus)

    mvn deploy:deploy-file -DgroupId=taobao-sdk -DartifactId=taobao-sdk-java -Dversion=1.0 -Dpackaging=j ...

  3. Halcon除法

    今天,用到了Halcon 的除法.求出两个region的面积,area1,area2.我想求出它们的比值area1/area2.但是发现比值是整数,没有保留小数.应该改为这样area1/real(ar ...

  4. Mesh属性[Unity]

    Mesh属性[Unity] Mesh是Unity内的一个组件,称为网格组件.3D网格是Unity中最重要的图形元素.在Unity中存在多种组件用于渲染标准网格或者蒙皮网格.拖尾或者3D线条. 在Uni ...

  5. https://segmentfault.com/a/1190000014637728

    原网站地址:https://segmentfault.com/a/1190000009657295#articleHeader3 基于 vue2 + element-ui 构建的后台管理系统 vue. ...

  6. hadoop的job执行在yarn中内存分配调节————Container [pid=108284,containerID=container_e19_1533108188813_12125_01_000002] is running beyond virtual memory limits. Current usage: 653.1 MB of 2 GB physical memory used

    实际遇到的真实问题,解决方法: 1.调整虚拟内存率yarn.nodemanager.vmem-pmem-ratio (这个hadoop默认是2.1) 2.调整map与reduce的在AM中的大小大于y ...

  7. 云笔记项目-网页端debug功能学习

    在做云笔记项目的过程中,除了服务端在eclipse中debug调试代码外,有时候需要在浏览器端也需要进行debug调试,刘老师举了一个冒泡排序算法的dubug例子,进行了讲解. 首先上浏览器端测试代码 ...

  8. 正确理解c和c ++的复杂类型声明

    本文作者girlrong是网易广州社区的C语言版版主,这篇文章被选在精华区.很是不错,不敢独享!据说她乐于助人,虚心诚恳,颇受网友欢迎.只可惜现在已退隐江湖了.在最近学习C语言过程中,了解些前辈大牛的 ...

  9. php-beanstalkd消息队列类分享

    <?php namespace Common\Business; /** * beanstalk: A minimalistic PHP beanstalk client. * * Copyri ...

  10. Aspose.word

    http://my.oschina.net/dancefires/blog/217858