基于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的不同端口号),集群中不同节点责任是不一样的. ...
随机推荐
- echarts 折线拐点收藏
拐点的样式有:
- python2 配置环境变量
复习 '''重点:1.进制转换:二进制 与 十六进制2.内存分布:栈区 与 堆区 # 124810101001110111 => 2a77abf1 => 1010101111110001 ...
- 汇编语言笔记v1.0
1.loop的用法 loop指令的格式是:loop标号,cpu执行loop指令的时候,要进行两步操作 1:(cx)=(cx)-1 2:判断cx中的值,不为零则转至标号处执行,如果为零,则向下执行 这里 ...
- 微信小程序开发——点击按钮退出小程序的实现
微信小程序官方是没有提供退出的API的,但是在navigator这个组件中,是有退出这个功能的:详情参考官方文档:navigator.示例代码:1 navigator open-type=" ...
- idea编译错误提示编译版本不对,需要注意的配置
- Numerical Analysis
PART1 <求解方程> 1,二分法 def bisect(f,a,b,TOL=0.000004): u_a = a u_b = b while(u_b-u_a)/2.0 > TO ...
- vue面试题总结
1.vue双向绑定的实现原理2.js的继承和原型链3.es6语法箭头函数和普通函数的区别 普通函数的this总是指向它的直接调用者. 在严格模式下,没找到直接调用者,则函数中的this是undefin ...
- 【medium】78. Subsets
求集合不重复的子集: 下面python的写法很好啊! class Solution(object): def subsets(self, nums): """ :type ...
- JUC--volatiley&CAS
public class VolatileTest { public static void main(String[] args) { ThreadDemo td = new ThreadDemo( ...
- WPF 10天修炼 第十天- WPF数据绑定
WPF数据绑定 数据绑定到元素属性是将源对象指定为一个WPF元素,并且源属性是一个依赖属性,依赖属性内置了变更通知.当改变源对象依赖属性值之后,绑定目标可以立即得到更新,开发人员不需要手动编写响应事件 ...