redis哨兵搭建

1、复制配置文件到conf

#单机安装以后
[root@t3 redis-5.0.8]# pwd
/app/redis-5.0.8
[root@t3 redis-5.0.8]# cp sentinel.conf ../redis/conf/
#复制三份
[root@t3 conf]# mv sentinel.conf sentinel_26379.conf  
[root@t3 conf]# cp sentinel_26379.conf sentinel_26380.conf  
[root@t3 conf]# cp sentinel_26379.conf sentinel_26381.conf
#日志文件创建三个
[root@t3 logs]# pwd
/app/redis/logs
[root@t3 logs]# touch {sentinel_26379.log,sentinel_26380.log,sentinel_26381.log}
#创建三个pid文件
[root@t3 pid]# pwd
/app/redis/pid
[root@t3 pid]# touch {sentinel_26379.pid,sentinel_26380.pid,sentinel_26381.pid}

2、更改配置文件

#更改26379的配置文件
bind 192.168.47.190
port 26379
daemonize yes
pidfile "/app/redis/pid/sentinel_26379.pid"
logfile "/app/redis/logs/sentinel_26379.log"
dir "/app/redis/data"
#sentinel myid d9730ea7211a7aa362e2ea9b8659f2ac83010473
sentinel deny-scripts-reconfig yes
#指向主服务器的IP端口
sentinel monitor mymaster 192.168.47.188 6379 2
sentinel auth-pass mymaster 123456
sentinel config-epoch mymaster 0
sentinel leader-epoch mymaster 0
protected-mode no
sentinel known-replica mymaster 192.168.47.189 6379
sentinel current-epoch 0

#26380的改端口,pid、log即可
bind 192.168.47.190
port 26380
daemonize yes
pidfile "/app/redis/pid/sentinel_26380.pid"
logfile "/app/redis/logs/sentinel_26380.log"
dir "/app/redis/data"
#sentinel myid d9730ea7211a7aa362e2ea9b8659f2ac83010473
sentinel deny-scripts-reconfig yes
sentinel monitor mymaster 192.168.47.188 6379 2
sentinel auth-pass mymaster 123456
sentinel config-epoch mymaster 0
sentinel leader-epoch mymaster 0
protected-mode no
sentinel known-replica mymaster 192.168.47.189 6379
sentinel current-epoch 0

#26381的改端口,pid、log即1
bind 192.168.47.190
port 26381
daemonize yes
pidfile "/app/redis/pid/sentinel_26381.pid"
logfile "/app/redis/logs/sentinel_26381.log"
dir "/app/redis/data"
#sentinel myid d9730ea7211a7aa362e2ea9b8659f2ac83010473
sentinel deny-scripts-reconfig yes
sentinel monitor mymaster 192.168.47.188 6379 2
sentinel auth-pass mymaster 123456
sentinel config-epoch mymaster 0
sentinel leader-epoch mymaster 0
protected-mode no
sentinel known-replica mymaster 192.168.47.189 6379
sentinel current-epoch 0

3、启动验证

3.1、启动

[root@t3 conf]# pwd
/app/redis/conf
[root@t3 conf]# ../bin/redis-sentinel sentinel_26379.conf
[root@t3 conf]# ../bin/redis-sentinel sentinel_26380.conf
[root@t3 conf]# ../bin/redis-sentinel sentinel_26381.conf

3.2、验证

#cli连接
[root@t3 bin]# ./redis-cli -h 192.168.47.190 -p 26381
#查看master信息
192.168.47.190:26379> sentinel master mymaster
1) "name"
2) "mymaster"
3) "ip"
4) "192.168.47.188"
5) "port"
6) "6379"
7) "runid"
8) "7ad0e4a8cede117bb1f7a2a7deb040a460e96a88"
9) "flags"
10) "master"
#查看slaves信息
192.168.47.190:26379> SENTINEL slaves mymaster
1)  1) "name"
   2) "192.168.47.189:6379"
   3) "ip"
   4) "192.168.47.189"
   5) "port"
   6) "6379
#master的IP地址和端口
192.168.47.190:26379> SENTINEL get-master-addr-by-name mymaster
1) "192.168.47.188"
2) "6379"
#查看sentinel信息看到有三个
192.168.47.190:26379> info sentinel
# Sentinel
sentinel_masters:1
sentinel_tilt:0
sentinel_running_scripts:0
sentinel_scripts_queue_length:0
sentinel_simulate_failure_flags:0
master0:name=mymaster,status=ok,address=192.168.47.188:6379,slaves=1,sentinels=3
#到此算是搭建完成拉,把master干掉看看能不能切换过去交给你们自己咯!

4、配置文件详解

# 绑定IP地址
bind 192.168.47.190

#此Sentinel实例运行的端口
port 26379

#后台运行yes
daemonize yes

#pid文件路径
pidfile "/app/redis/pid/sentinel_26379.pid"

#日志文件路径
logfile "/app/redis/logs/sentinel_26379.log"

#工作目录
dir "/app/redis/data"

#因为配置文件是复制的这个参数都是一样的,启动sentinel检查发现一个一sentinel(注释掉)
#sentinel myid d9730ea7211a7aa362e2ea9b8659f2ac83010473
sentinel deny-scripts-reconfig yes
##mymaster是集群的名称可自定义,IP地为集群中master的地址,注意与bind的区别 6379表示端口 2表示 需要多少哨兵同意才能执行故障转移操作
sentinel monitor mymaster 192.168.47.188 6379 2

#如果redis配置了密码,那这里必须配置认证,否则不能自动切换
sentinel auth-pass mymaster 123456
#哨兵程序自动添加的部分
sentinel config-epoch mymaster 0
sentinel leader-epoch mymaster 0

# 保护模式(是否禁止外部链接,除绑定的ip地址外)
protected-mode no

#指明了当前群集的从库的ip和端口,在主从切换时该值会改变
sentinel known-replica mymaster 192.168.47.189 6379
#除了当前的哨兵还有哪些监控的哨兵
sentinel current-epoch 0

问题: -failover-abort-no-good-slave master mymaster 172.16.55.131 6379
已解决 所有的redis.conf 的bind 127.0.0.1 改为bind 0.0.0.0 从节点bind没有重新写 汗死 重启解决

日志:

23882:X 07 Jul 2020 17:26:27.285 # +new-epoch 3
23882:X 07 Jul 2020 17:26:27.285 # +try-failover master mymaster 192.168.47.188 6379
23882:X 07 Jul 2020 17:26:27.286 # +vote-for-leader dc1a501112507435fe18cb8db2edbcb1b5117d10 3
23882:X 07 Jul 2020 17:26:27.289 # 7f5b2e6da8bede8dac1d5f970e9c81a64f63eff2 voted for dc1a501112507435fe18cb8db2edbcb1b5117d10 3
23882:X 07 Jul 2020 17:26:27.290 # 6e7620bb5aad69e54899dbc71838a841b4a63cf8 voted for dc1a501112507435fe18cb8db2edbcb1b5117d10 3
23882:X 07 Jul 2020 17:26:27.387 # +elected-leader master mymaster 192.168.47.188 6379
23882:X 07 Jul 2020 17:26:27.387 # +failover-state-select-slave master mymaster 192.168.47.188 6379
23882:X 07 Jul 2020 17:26:27.488 # +selected-slave slave 192.168.47.189:6379 192.168.47.189 6379 @ mymaster 192.168.47.188 6379
23882:X 07 Jul 2020 17:26:27.488 * +failover-state-send-slaveof-noone slave 192.168.47.189:6379 192.168.47.189 6379 @ mymaster 192.168.47.188 6379
23882:X 07 Jul 2020 17:26:27.572 * +failover-state-wait-promotion slave 192.168.47.189:6379 192.168.47.189 6379 @ mymaster 192.168.47.188 6379
23882:X 07 Jul 2020 17:26:28.485 # +promoted-slave slave 192.168.47.189:6379 192.168.47.189 6379 @ mymaster 192.168.47.188 6379
23882:X 07 Jul 2020 17:26:28.485 # +failover-state-reconf-slaves master mymaster 192.168.47.188 6379
23882:X 07 Jul 2020 17:26:28.543 # +failover-end master mymaster 192.168.47.188 6379
23882:X 07 Jul 2020 17:26:28.543 # +switch-master mymaster 192.168.47.188 6379 192.168.47.189 6379
23882:X 07 Jul 2020 17:26:28.543 * +slave slave 192.168.47.188:6379 192.168.47.188 6379 @ mymaster 192.168.47.189 6379
23882:X 07 Jul 2020 17:26:58.559 # +sdown slave 192.168.47.188:6379 192.168.47.188 6379 @ mymaster 192.168.47.189 6379

###查看是否能切换

192.168.47.190:26379> SENTINEL get-master-addr-by-name mymaster
1) "192.168.47.189"
2) "6379"

192.168.47.190:26379> SENTINEL get-master-addr-by-name mymaster1) "192.168.47.189"2) "6379"

redis哨兵搭建的更多相关文章

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

    目录 redis单点.redis主从.redis哨兵 sentinel,redis集群cluster配置搭建与使用 1 .redis 安装及配置 1.1 redis 单点 1.1.2 在命令窗口操作r ...

  2. Redis哨兵(sentinel)模式搭建

    一.Sentinel介绍 之前骚了一波Redis的简介及应用场景,今天试了下他的哨兵模式: Sentinel是Redis的高可用性(HA)解决方案,由一个或多个Sentinel实例组成的Sentine ...

  3. Redis哨兵功能与集群搭建

    6.redis哨兵功能 Redis-Sentinel Redis-Sentinel是redis官方推荐的高可用性解决方案,当用redis作master-slave的高可用时,如果master本身宕机, ...

  4. redis环境搭建及一主二从三哨兵模式配置

    一.单机redis环境搭建 1.安装: OS:linux redhat6.5 下载redis 官网下载链接:https://redis.io/download 把安装包上传到服务器,进行解压 [roo ...

  5. 搭建redis哨兵模式

    搭建redis哨兵模式,一主两从三哨兵   1.从官网下载redis安装包:此处是redis-5.0.7.tar.gz 2.上传到目录 /utxt/soft 3.解压 4.cd /utxt/soft/ ...

  6. redis 哨兵机制环境搭建

    Redis哨兵机制,一主二从 注:Redis哨兵切换,建议一主多从 一.一主二从 教程步骤:https://www.cnblogs.com/zwcry/p/9046207.html 二.哨兵配置(se ...

  7. redis哨兵集群搭建

    下载redis jar包redis-4.0.11.tar.gz放在/data/redis目录下 解压 命令:tar -zxvf redis-4.0.11.tar.gz 解压后如图所示 在/usr/lo ...

  8. Redis 哨兵

    作用 Redis Sentinel,即Redis哨兵,在Redis 2.8版本开始引入. 主要提供了配置提供者,通知,哨兵的监控和自动故障转移功能.哨兵的核心功能是主节点的自动故障转移. 下面是Red ...

  9. redis哨兵集群、docker入门

    redis-sentinel主从复制高可用 Redis-Sentinel Redis-Sentinel是redis官方推荐的高可用性解决方案,当用redis作master-slave的高可用时,如果m ...

随机推荐

  1. Vue官方文档Vue.extend、Vue.component、createElement、$attrs/$listeners、插槽的深入理解

    一.Vue.extend({}). 看官网文档介绍,Vue.extend({})返回一个Vue的子类,那么这个Vue子类是啥玩意儿呢?我直观感觉它就是创建出一个组件而已啊,那么它又和Vue.compo ...

  2. Sunday算法解决字符串匹配问题

    概述 提起字符串匹配可能更多人会想到KMP算法,该算法时间复杂度为O(m+n),而且也是我们在学习数据结构过程中最早接触到的比较好的算法.但KMP算法需要在模式字符串有关联的情况下,也即模式字符串前后 ...

  3. CentOS如何设置IP连接网络

    1.登录系统,进入:cd /etc/sysconfig/network-scripts 目录下,如下图: 找到 ifcfg-ens33(文件) 第二步:使用vi编辑器打开ifcfg-ens33文件,使 ...

  4. SpringAOP+源码解析,切就完事了

    本文是对近期学习知识的一个总结,附带源码注释及流程图,如有不足之处,还望评论区批评指正. 目录 一.AOP.SpringAOP.AspectJ的区别 二.AOP关键术语 三.通知的五种类型 四.切入点 ...

  5. Linux:nginx基础

    一..简单介绍 nginx时开源的www服务器,只能解析静态的网页(html,js,css等),具有静态小文件高并发特性. 可做web服务器.负载均衡.web cache(web缓存) 优点: 1.高 ...

  6. 你准备好开始DevOps了吗?

    前面一章节我们已经了解了Agile,CI/CD,DevOps,作为DevOps的起点,对于一个团队,如何开始自己的持续集成?根据我的经验,列出了一下需要考虑的点 1. 代码管理/分支策略 代码托管在哪 ...

  7. Node.js向MongoDB中插入并查询数据

    首先必须要保持Node.js与MongoDB保持连接 具体教程见:Node.js连接MongoDB数据库步骤 插入数据步骤如下 node项目文件如下:在routes文件夹下新建insert.js文件, ...

  8. oracle之二物化视图

    物化视图 18.1.物化视图作用 1) 物化视图起源于数据仓库,早期的考虑是用于预先计算并保存表连接或聚集等耗时较多的操作的结果,这样,在执行查询时,就可以避免在基表上进行这些耗时的操作,从而快速的得 ...

  9. java Spring系列之 配置文件的操作 +Bean的生命周期+不同数据类型的注入简析+注入的原理详解+配置文件中不同标签体的使用方式

    Spring系列之 配置文件的操作 写在文章前面: 本文带大家掌握Spring配置文件的基础操作以及带领大家理清依赖注入的概念,本文涉及内容广泛,如果各位读者耐心看完,应该会对自身有一个提升 Spri ...

  10. Spring基于XML的IOC环境搭建及入门

    一.使用Maven构建Java项目 * 项目目录结构 1. 在sun.service包下创建UserDao接口和接口实现类: UserDao接口: package sun.service; /** * ...