美文网首页
Mac下搭建Redis5-主从+哨兵

Mac下搭建Redis5-主从+哨兵

作者: 一触天开 | 来源:发表于2019-12-20 00:49 被阅读0次

哨兵机制
有了主从,那我们需要对其进行监控,Sentinel会不断地检查你的主服务器和从服务器是否运作正常。某个节点故障后,Sentinel 会开始一次自动故障迁移操作, 它会将失效主服务器的其中一个从服务器升级为新的主服务器, 并让失效主服务器的其他从服务器改为复制新的主服务器; 当客户端试图连接失效的主服务器时, 集群也会向客户端返回新主服务器的地址, 使得集群可以使用新主服务器代替失效服务器。Redis Sentinel 是一个分布式系统, 你可以在一个架构中运行多个 Sentinel 进程(Progress), 这些进程使用流言协议(Gossip Protocols)来接收关于主服务器是否下线的信息, 并使用投票协议(Agreement Protocols)来决定是否执行自动故障迁移, 以及选择哪个从服务器作为新的主服务器。虽然 Redis Sentinel 释出为一个单独的可执行文件 redis-sentinel , 但实际上它只是一个运行在特殊模式下的 Redis 服务器。

本文件的配置文件及脚本在gitee上可查看 https://gitee.com/akonvm/redis-demo/tree/master/masterslave

sentinel是在主从模式上建立的,所有sentinel服务都监听master,它会自动检测到slave以及其它sentinel。所以主从搭建过程使用前一篇(Mac下搭建Redis5-主从模式)搭建好的服务即可,下面介绍在该主从架构上设置sentinel

1. 高可用架构图

图中实线标识需要在配置文件中指定的关系,虚线是自动检测到的关系


高可用架构图

2. sentinel配置文件

redis解压目录下提供了sentinel的配置文件模块sentinel.conf,将他拷贝过来修改即可

$ cd /Users/ankang/develop/redis-demo/masterslave/conf
$ cp /Users/ankang/develop/redis-5.0.7/sentinel.conf redis-sentinel-26379.conf

redis-sentinel-26379.conf配置如下

# 关闭保护模式
protected-mode no
# 设定端口
port 26379
# 修改为守护模式,使之可以后台运行
daemonize yes
# 设置进程文件
pidfile "/var/run/redis-sentinel-26379.pid"
# 设置进日志文件
logfile "/Users/ankang/develop/redis-demo/masterslave/logs/redis-sentinel-26379.log"
# 哨兵sentinel监控的redis主节点的 
## ip:主机ip地址
## port:哨兵端口号
## master-name:可以自己命名的主节点名字(只能由字母A-z、数字0-9 、这三个字符".-_"组成。)
## quorum:当这些quorum个数sentinel哨兵认为master主节点失联 那么这时 客观上认为主节点失联了  
# sentinel monitor <master-name> <ip> <redis-port> <quorum>  
sentinel monitor mymaster 127.0.0.1 6379 2
# 当在Redis实例中开启了requirepass <foobared>,所有连接Redis实例的客户端都要提供密码。
# sentinel auth-pass <master-name> <password>
sentinel auth-pass mymaster admin123
# master或slave多长时间(默认30秒)不能使用后标记为s_down状态。
sentinel down-after-milliseconds mymaster 5000
# 若sentinel在该配置值内未能完成failover操作(即故障时master/slave自动切换),则认为本次failover失败。
sentinel failover-timeout mymaster 10000
# myid在sentinel启动时会自动生成.多哨兵拷贝配置文件时不要拷贝该字段,需要删掉,否则故障切换不生效
# sentinel myid xxxxxxxxxxxxxx

redis-sentinel-26380.confredis-sentinel-26381.confredis-sentinel-26379.conf基本一样,只需要修改文件中的portpidfilelogfile对应的端口

3. 添加启动脚本

/Users/ankang/develop/redis-demo/masterslave/目录下创建脚本redis-sentinel-26379.shredis-sentinel-26380.shredis-sentinel-26381.shredis-sentinel-26379.sh内容如下

#!/bin/sh
set -e

REDISPORT=26379
INSTALL_DIR="/Users/ankang/develop/redis-5.0.7"
DEMO_DIR="/Users/ankang/develop/redis-demo/masterslave"
EXEC="${INSTALL_DIR}/src/redis-sentinel"
CONF="${DEMO_DIR}/conf/redis-sentinel-${REDISPORT}.conf"

case "$1" in
    start)
        echo "Starting Redis sentinel..."
        $EXEC $CONF
        ;;
    stop)
        pid=`ps aux | grep redis-sentinel | grep ${REDISPORT} | head -n 1 | awk '{print $2}'`
        if [ -n "$pid" ]
        then
                echo "Stopping Redis sentinel[${pid}]..."
                kill ${pid}
        else
                echo "Redis sentinel stopped"
        fi
        ;;
    *)
        echo "Please use start or stop as first argument"
        ;;
esac

redis-sentinel-26380.shredis-sentinel-26381.sh可以拷贝redis-sentinel-26379.sh,对应修改文件中的REDISPORT变量的端口号即可

4. 启动与关闭

按下面命令执行

$ sh redis-sentinel-26379.sh start
$ sh redis-sentinel-26380.sh start
$ sh redis-sentinel-26381.sh start

注意:sentinel启动后,对应的配置文件会被自动修改

5. 故障迁移

这时关闭master服务,过一会其他的slave服务会自动切换为master,通过info可查看。

相关文章

  • Mac下搭建Redis5-主从+哨兵

    哨兵机制有了主从,那我们需要对其进行监控,Sentinel会不断地检查你的主服务器和从服务器是否运作正常。某个节点...

  • Mac下搭建Redis5-主从模式

    在上一篇文章中介绍了Mac下搭建Redis5-单机模式,下面介绍Mac下搭建Redis5的主从模式,搭建过程基于上...

  • redis集群

    一,主从复制搭建 哨兵

  • SpringBoot整合Redis哨兵模式

    SpringBoot整合Redis哨兵模式 主从搭建 点击哨兵搭建 点击 配置 yaml 依赖 连接池

  • 5.Redis的哨兵服务

    0.Redis主从架构的问题1.哨兵服务介绍2.架构图3.主从服务搭建4.配置哨兵服务5.启动哨兵服务6.验证哨兵...

  • redis集群

    reids的集群搭建方式有三种主从master-slave、哨兵Sentinel、集群Cluster 主从mast...

  • redis哨兵集群搭建

    今天我们介绍redis的哨兵集群的搭建过程。之前的文章中我们介绍了redis 的主从搭建的方式,但是主从集群的方式...

  • redis集群模式:redis单点、redis主从、redis哨

    目录 redis单点、redis主从、redis哨兵 sentinel,redis集群cluster配置搭建与使用...

  • redis(二)

    Redis用户认证 禁用危险命令 主从复制的过程 主从复制的部署 哨兵 Redis哨兵+主从+密码 Redis哨兵...

  • redis主从+哨兵搭建

    在redis主从搭建基础上代码搭建哨兵1、程序目录下创建sentinel目录2、创建3配置文件 端口分别是2638...

网友评论

      本文标题:Mac下搭建Redis5-主从+哨兵

      本文链接:https://www.haomeiwen.com/subject/fwxbnctx.html