基于docker实现哨兵集群部署
简单dockerfile文件,用于演示sentinel哨兵故障转移
FROM centos:latest
MAINTAINER BIXIAOYU
RUN groupadd -r redis &&useradd -r -g redis redis
RUN yum -y update && yum -y install epel-release && yum -y install redis && yum -y install net-tools
EXPOSE 6379
# docker build --no-cache -t redis .
启动docker容器实例
docker run -itd --name redis-master --net=mynetwork -p 6383:6379 --ip 172.60.0.3 redis
docker run -itd --name redis-slave1 --net=mynetwork -p 6384:6379 --ip 172.60.0.4 redis
docker run -itd --name redis-slave2 --net=mynetwork -p 6385:6379 --ip 172.60.0.5 redis
docker run -itd --name redis-sentinel1 --net=mynetwork -p : --ip 172.60.0.5 redis
docker run -itd --name redis-sentinel2 --net=mynetwork -p : --ip 172.60.0.6 redis
docker run -itd --name redis-sentinel3 --net=mynetwork -p : --ip 172.60.0.7 redis
#docker network create --subnet=172.60.0.0/16 mynetwork

【配置】
先完成主从同步,主从同步的配置可参考https://www.cnblogs.com/bixiaoyu/p/10706811.html这篇文章,在此就不必细说了,重点是sentinel的配置
bind 0.0.0.0 #设置允许访问的IP,这里仍然设置0.0.0.0
protected-mode no #允许在连接时,密码为空
port
dir "/tmp"
sentinel myid 6d0d4099c13cdeab018e1f2005455be6f1cd6f6b
sentinel monitor mymaster 172.60.0.3 2 #设置监听
sentinel config-epoch mymaster
sentinel leader-epoch mymaster
logfile "/var/log/redis/sentinel.log"
sentinel known-slave mymaster 172.60.0.2
sentinel known-slave mymaster 172.60.0.4
sentinel known-sentinel mymaster 172.60.0.7 dfce433e021aa3e82276974aa12fa0684fb0b4f0
sentinel known-sentinel mymaster 172.60.0.6 ceb363cf84103950cfa2a785816c4e8a36c02143
sentinel current-epoch


选择一个sentinel节点,查看日志信息,发现默认主节点为172.60.0.2

【测试故障转移】
先通过pkill模拟故障master故障宕机,随后观察哨兵任意节点的情况

我们可以从下面sentinel节点上看到172.0.0.3被选举成为新主节点
[root@ef77b61448fc /]# tail /var/log/redis/sentinel.log
:X Apr ::26.472 * +sentinel sentinel ceb363cf84103950cfa2a785816c4e8a36c02143 172.60.0.6 @ mymaster 172.60.0.2
:X Apr ::24.154 * +sentinel sentinel dfce433e021aa3e82276974aa12fa0684fb0b4f0 172.60.0.7 @ mymaster 172.60.0.2
:X Apr ::05.724 # +sdown master mymaster 172.60.0.2
:X Apr ::05.895 # +new-epoch
:X Apr ::05.895 # +vote-for-leader dfce433e021aa3e82276974aa12fa0684fb0b4f0
:X Apr ::06.276 # +config-update-from sentinel dfce433e021aa3e82276974aa12fa0684fb0b4f0 172.60.0.7 @ mymaster 172.60.0.2
:X Apr ::06.276 # +switch-master mymaster 172.60.0.2 172.60.0.3
:X Apr ::06.276 * +slave slave 172.60.0.4: 172.60.0.4 @ mymaster 172.60.0.3
:X Apr ::06.276 * +slave slave 172.60.0.2: 172.60.0.2 @ mymaster 172.60.0.3
查看sentinel节点的日志信息

此时,我们把pkill掉的172.60.0.2(旧主节点)重启,在看看新任Master主节点172.60.0.3有何变化
重启的旧主节点成为从节点并加入进来,此时正在进行复制动作,offset的偏移量还没有同步一致,

【小结】
进入哨兵节点客户端执行SENTINEL masterts命令显示被监控的所有master以及状态
127.0.0.1:> SENTINEL masters
) ) "name"
) "mymaster" #被监控主节点的名称
) "ip"
) "172.60.0.3" #被监控主节点的IP
) "port"
) ""
) "runid"
) "dd3696a2793e4e19892fca48793d75cec3f07bea" #被监控主节点的runid值
) "flags"
) "master"
) "link-pending-commands"
) ""
) "link-refcount"
) ""
) "last-ping-sent"
) ""
) "last-ok-ping-reply"
) ""
) "last-ping-reply"
) ""
) "down-after-milliseconds"
) "" #监控节点不可达超时时间
) "info-refresh"
) ""
) "role-reported"
) "master"
) "role-reported-time"
) ""
) "config-epoch"
) ""
) "num-slaves" #检测剩余slave节点个数
) ""
) "num-other-sentinels" #检测其它sentinel节点个数
) ""
) "quorum" #允许主节点不可用的sentinels的数量(最多允许两个sentinel节点故障)
) ""
) "failover-timeout" #延迟时间
) ""
) "parallel-syncs" #复制转移数量
) ""
执行SENTINEL slaves mymastert查看从节点信息,此时你会看到两个从节点
) ) "name"
) "172.60.0.2:6379"
) "ip"
) "172.60.0.2"
) "port"
) ""
) "runid"
) "3ede55439a3ce6fb1ab171ed7fd6b6c639725966"
) "flags"
) "slave"
) "link-pending-commands"
) ""
) "link-refcount"
) ""
) "last-ping-sent"
) ""
) "last-ok-ping-reply"
) ""
) "last-ping-reply"
) ""
) "down-after-milliseconds"
) ""
) "info-refresh"
) ""
) "role-reported"
) "slave"
) "role-reported-time"
) ""
) "master-link-down-time"
) ""
) "master-link-status"
) "ok"
) "master-host"
) "172.60.0.3"
) "master-port"
) ""
) "slave-priority"
) ""
) "slave-repl-offset"
) ""
) ) "name"
) "172.60.0.4:6379"
) "ip"
) "172.60.0.4"
) "port"
) ""
) "runid"
) "f17cfcfc4b9217e1f5a3c0d0a2c55d82da46c37e"
) "flags"
) "slave"
) "link-pending-commands"
) ""
) "link-refcount"
) ""
) "last-ping-sent"
) ""
) "last-ok-ping-reply"
) ""
) "last-ping-reply"
) ""
) "down-after-milliseconds"
) ""
) "info-refresh"
) ""
) "role-reported"
) "slave"
) "role-reported-time"
) ""
) "master-link-down-time"
) ""
) "master-link-status"
) "ok"
) "master-host"
) "172.60.0.3"
) "master-port"
) ""
) "slave-priority"
) ""
) "slave-repl-offset"
) ""
查看主节点的端口
127.0.0.1:> sentinel get-master-addr-by-name mymaster
) "172.60.0.3"
) ""
执行sentinel failover mymaster命令,强制切换主节点!下图所示,发现主节点已经由172.60.0.3变为172.60.0.2了,


待更。。。。
基于docker实现哨兵集群部署的更多相关文章
- 庐山真面目之十二微服务架构基于Docker搭建Consul集群、Ocelot网关集群和IdentityServer版本实现
庐山真面目之十二微服务架构基于Docker搭建Consul集群.Ocelot网关集群和IdentityServer版本实现 一.简介 在第七篇文章<庐山真面目之七微服务架构Consul ...
- 基于Docker的redis集群搭建
Redis集群官方介绍:http://www.redis.cn/topics/cluster-tutorial.html 基于Docker搭建Redis集群 环境:6个节点,三主三从 制作Redis镜 ...
- Docker学习-Kubernetes - 集群部署
Docker学习 Docker学习-VMware Workstation 本地多台虚拟机互通,主机网络互通搭建 Docker学习-Docker搭建Consul集群 Docker学习-简单的私有Dock ...
- 基于docker安装pxc集群
基于docker安装pxc集群 一.PXC 集群的安装 PXC集群比较特殊,需要安装在 linux 或 Docker 之上.这里使用 Docker进行安装! Docker的镜像仓库中包含了 PXC数据 ...
- 基于docker搭建elasticsearch集群
es集群的搭建 - 基于单机搭建elasticsearch集群见官网 https://www.elastic.co/guide/en/elasticsearch/reference/current/d ...
- 【Redis学习专题】- Redis主从+哨兵集群部署
集群版本: redis-4.0.14 集群节点: 节点角色 IP redis-master 10.100.8.21 redis-slave1 10.100.8.22 redis-slave2 10.1 ...
- 基于pgpool搭建postgressql集群部署
postgresql集群搭建 基于pgpool中间件实现postgresql一主多从集群部署,这里用两台服务器作一主一从示例 虚拟机名 IP 主从划分 THApps 192.168.1.31 主节点 ...
- 基于minikube的kubernetes集群部署及Vitess最佳实践
简介 minikube是一个可以很容易在本地运行Kubernetes集群的工具, minikube在电脑上的虚拟机内运行单节点Kubernetes集群,可以很方便的供Kubernetes日常开发使用: ...
- 基于Docker的Consul集群实现服务发现
服务发现 其实简单说,服务发现就是解耦服务与IP地址之间的硬绑定关系,以典型的集群为例,对于集群来说,是有多个节点的,这些节点对应多个IP(或者同一个IP的不同端口号),集群中不同节点责任是不一样的. ...
随机推荐
- Java基础 -- 深入理解Java异常机制
异常指不期而至的各种状况,如:文件找不到.网络连接失败.非法参数等.异常是一个事件,它发生在程序运行期间,干扰了正常的指令流程.Java通 过API中Throwable类的众多子类描述各种不同的异常. ...
- C# activex开发中 axwebbrowser控件及 IE浏览器设置
<object type='application/x-vlc-plugin' id='vlc' events='True' codebase='../cab/axvlc.cab' classi ...
- C/C++中的输入输出重定向
目录 一 C/C++中的输入输出重定向 1.1 C语言输入输出重定向 1.2 C++语言输入输出重定向 参考资料 注:原创不易,转载请务必注明原作者和出处,感谢支持! 一 C/C++中的输入输出重定向 ...
- react native头部标题样式修改
navigationOptions: ({navigation}) => ({ headerTitle:'评估记录', headerBackTitle:null, headerLeft:null ...
- CTR预估中GBDT与LR融合方案(转载)
1.背景 CTR预估,广告点击率(Click-Through Rate Prediction)是互联网计算广告中的关键环节,预估准确性直接影响公司广告收入.CTR预估中用的最多的模型是LR(Logis ...
- Debian Security Advisory DSA-4421-1 chromium security update
Debian Security Advisory DSA-4421-1 chromium security update Package : chromiumCVE ID ...
- React Router 4.x 开发,这些雷区我们都帮你踩过了
前言 在前端框架层出不穷的今天,React 以其虚拟 DOM .组件化开发思想等特性迅速占据了主流位置,成为前端开发工程师热衷的 Javascript 库.作为 React 体系中的重要组成部分:Re ...
- 第十三届东北师范大学程序设计竞赛热身赛 C(exgcd+欧拉函数)
题目链接 思路 对于答案,我们考虑对于每个可行的$c$会和多少$d$产生合法序偶.首先证明$c$和$b$必然互质. 假设$c$和$b$不互质,那么设$t_{1}=gcd(c, b),(t_{1} &g ...
- hibernate之一对多,多对一
配置文件 <!--一对多--><!--name:集合属性名字 column:外键列名 class:与它相关的对象的完整列名 cascade:级联操作:分3种 save-update: ...
- 红警大战JAVA简单版
代码结构: 相关源码: 武器类: 属性:武器,攻击力,子弹数量. 方法:给属性赋值(set属性()方法) 获取属性值(get属性()方法) package 红警大战简单版; public class ...