【集群】Redis的哨兵模式和集群模式
哨兵模式
哨兵模式是redis高可用的实现方式之一
使用一个或者多个哨兵(Sentinel)实例组成的系统,对redis节点进行监控,在主节点出现故障的情况下,能将从节点中的一个升级为主节点,进行故障转义,保证系统的可用性。
哨兵们是怎么感知整个系统中的所有节点(主节点/从节点/哨兵节点)的
- 首先主节点的信息是配置在哨兵(Sentinel)的配置文件中
 - 哨兵节点会和配置的主节点建立起两条连接
命令连接和订阅连接 - 哨兵会通过
命令连接每10s发送一次INFO命令,通过INFO命令,主节点会返回自己的run_id和自己的从节点信息 - 哨兵会对这些从节点也建立两条连接
命令连接和订阅连接 - 哨兵通过
命令连接向从节点发送INFO命令,获取到他的一些信息
a. run_id
b. role
c. 从服务器的复制偏移量 offset
d. 等 - 因为哨兵对与集群中的其他节点(主从节点)当前都有两条连接,
命令连接和订阅连接
a. 通过命令连接向服务器的_sentinel:hello频道发送一条消息,内容包括自己的ip端口、run_id、配置纪元(后续投票的时候会用到)等
b. 通过订阅连接对服务器的_sentinel:hello频道做了监听,所以所有的向该频道发送的哨兵的消息都能被接受到
c. 解析监听到的消息,进行分析提取,就可以知道还有那些别的哨兵服务节点也在监听这些主从节点了,更新结构体将这些哨兵节点记录下来
d. 向观察到的其他的哨兵节点建立命令连接----没有订阅连接 
哨兵模式下的故障迁移
主观下线
哨兵(Sentinel)节点会每秒一次的频率向建立了命令连接的实例发送PING命令,如果在down-after-milliseconds毫秒内没有做出有效响应包括(PONG/LOADING/MASTERDOWN)以外的响应,哨兵就会将该实例在本结构体中的状态标记为SRI_S_DOWN主观下线
客观下线
当一个哨兵节点发现主节点处于主观下线状态是,会向其他的哨兵节点发出询问,该节点是不是已经主观下线了。如果超过配置参数quorum个节点认为是主观下线时,该哨兵节点就会将自己维护的结构体中该主节点标记为SRI_O_DOWN客观下线
询问命令SENTINEL is-master-down-by-addr <ip> <port> <current_epoch> <run_id>
| 参数 | 意义 | 
|---|---|
| ip/port | 当前认为下线的主节点的ip和端口 | 
| current_epoch | 配置纪元 | 
| run_id | *标识仅用于询问是否下线  有值标识该哨兵节点希望对方将自己设置为leader 询问时用*,选举时用run_id
 | 
leader选举
在认为主节点客观下线的情况下,哨兵节点节点间会发起一次选举,命令还是上面的命令SENTINEL is-master-down-by-addr <ip> <port> <current_epoch> <run_id>,只是run_id这次会将自己的run_id带进去,希望接受者将自己设置为主节点。如果超过半数以上的节点返回将该节点标记为leader的情况下,会有该leader对故障进行迁移
故障迁移
- 在从节点中挑选出新的主节点
a. 通讯正常
b. 优先级排序
c. 优先级相同是选择offset最大的 - 将该节点设置成新的主节点 
SLAVEOF no one,并确保在后续的INGO命令时,该节点返回状态为master - 将其他的从节点设置成从新的主节点复制, 
SLAVEOF命令 - 将旧的主节点变成新的主节点的从节点
 
优缺点
- 优点
高可用,在主节点故障时能实现故障的转移 - 缺点:好像没办法做到水平拓展,如果内容很大的情况下
 
集群模式
官方提供的分布式方案(槽指派/重新分片/故障转移)
集群内的节点,都会有个数据结构存储整个集群内的节点信息
//整体
struct clusterState{
  clusterNode *mySelf;
  ....
  dict *nodes;  //集群内的所有节点
}
// 单个节点
struct clusterNode {
  char name[];
  char ip[];
  int port;
  clusterLink *link;  //保存节点间,连接的信息
  int flags;    //状态标记
}
//节点间连接的信息
struct clusterLink{
  mstime_t ctime;  //创建时间
  int fd; //tcp套接字描述符
  sds sndbuf;  // 输出缓存区
  sds rcvbuf;  //输入缓存区
  struct clusterNode *node;
}
槽指派
redis集群可以被分为16384个槽,只有这些槽全被指派了处理的节点的情况下,集群的状态才能是上线状态(ok)
操作redis集群的时候,将key作为参数,就可以计算出对应的处理槽上,所以存储等操作都应该在该槽对应的节点上。通过这种方式,可以完美的实现集群存储的水平拓展。
def slot_number(key):
  return CRC16(key) & 16383
//得到的结果就是槽的序号
槽指派的信息是怎么存储的
struct clusterState{
  clusterNode *slots[16384]
 }
struct clusterNode{
  unsigned char slots[16384/8]
}
通过上面两个结构体中的定义可以看出,槽指派的信息是分了两种方式,保存在结构体里面。
分两种存储的好处
1. 如果需要判断某一个节点负责的槽,只需要获取方式二中的数组做判断就可以
2.如果找某个槽是哪个节点负责,只需要获取方式一的列表,一查就知道
重新分片
将已经指派给节点的槽,重新执行新的节点。

故障转移
发现故障节点
- 集群内的节点会向其他节点发送PING命令,检查是否在线
 - 如果未能在规定时间内做出PONG响应,则会把对应的节点标记为疑似下线
 - 集群中一半以上
负责处理槽的主节点都将主节点X标记为疑似下线的话,那么这个主节点X就会被认为是已下线 - 向集群广播主节点X
已下线,大家收到消息后都会把自己维护的结构体里的主节点X标记为已下线 
从节点选举
- 当从节点发现自己复制的主节点已下线了,会向集群里面广播一条消息,要求所有有投票权的节点给自己投票(
所有负责处理槽的主节点都有投票权) - 主节点会向第一个给他发选举消息的从节点回复支持
 - 当支持数量超过N/2+1的情况下,该从节点当选新的主节点
 
故障的迁移
- 新当选的从节点执行 
SLAVEOF no one,修改成主节点 - 新的主节点会撤销所有已下线的老的主节点的槽指派,指派给自己
 - 新的主节点向集群发送命令,通知其他节点自己已经变成主节点了,负责哪些槽指派
 - 新的主节点开始处理自己负责的槽的命令
 
集群模式和哨兵模式的区别
- 哨兵模式监控权交给了哨兵系统,集群模式中是工作节点自己做监控
 - 哨兵模式发起选举是选举一个leader哨兵节点来处理故障转移,集群模式是在从节点中选举一个新的主节点,来处理故障的转移
 
转自:https://www.jianshu.com/p/d6d2325a5ec7
【集群】Redis的哨兵模式和集群模式的更多相关文章
- Redis 主从集群搭建及哨兵模式配置
		
最近搭建了redis集群及哨兵模式,为方便以后查看特此记录下来: 1.Redis安装 2.主从架构 2.1 Redis主从架构图 2.2Redis主从结构搭建 Redis集群不用安装多个Redis,只 ...
 - Redis哨兵模式实现集群的高可用
		
先了解一下哨兵都 做了什么工作:Redis 的 Sentinel 系统用于管理多个 Redis 服务器(instance), 该系统执行以下三个任务: 监控(Monitoring): Sentinel ...
 - Redis集群--Redis集群之哨兵模式
		
echo编辑整理,欢迎转载,转载请声明文章来源.欢迎添加echo微信(微信号:t2421499075)交流学习. 百战不败,依不自称常胜,百败不颓,依能奋力前行.--这才是真正的堪称强大!!! 搭建R ...
 - Redis 单机模式,主从模式,哨兵模式(sentinel),集群模式(cluster),第三方模式优缺点分析
		
Redis 的几种常见使用方式包括: 单机模式 主从模式 哨兵模式(sentinel) 集群模式(cluster) 第三方模式 单机模式 Redis 单副本,采用单个 Redis 节点部署架构,没有备 ...
 - Docker:docker搭建redis一主多从集群(配置哨兵模式)
		
角色 实例IP 实例端口 宿主机IP 宿主机端口 master 172.19.0.2 6382 192.168.1.200 6382 slave01 172.19.0.3 6383 192.168.1 ...
 - Redis——(主从复制、哨兵模式、集群)的部署及搭建
		
Redis--(主从复制.哨兵模式.集群)的部署及搭建 重点: 主从复制:主从复制是高可用redis的基础,主从复制主要实现了数据的多机备份,以及对于读操作的负载均衡和简单的故障恢复. 哨兵和集群都是 ...
 - Redis三种模式——主从复制,哨兵模式,集群
		
一.Redis主从复制作用 数据冗余:主从复制实现了数据的热备份,是持久化之外的一种数据冗余方式. 故障恢复:当主节点出现问题时,可以由从节点提供服务,实现快速的故障恢复:实际上是一种服务的冗余. 负 ...
 - redis集群搭建和哨兵模式以及AOF和RDB持久化
		
Redis主从+哨兵模式 1.环境准备 (1)三台独立的linux主机 (2)IP分别为:10.150.200.182 (从) 10.150.200.184(从) 10.150.200.195(主) ...
 - redis的哨兵集群,redis-cluster
		
#主从同步redis主从优先1.保证数据安全,主从机器两份数据一主多从2.读写分离,缓解主库压力主redis,可读可写slave身份,只读 缺点1.手动主从切换假如主库挂了,得手动切换master ...
 
随机推荐
- vue-葵花宝典
			
router-view 中包含 router-view 这种情况就可以 使用嵌套路由了 变化的视图中包含变化的视图 代码层面 router-view 中 包含router-view 路由childre ...
 - leetcode-167周赛-1291-顺次数
			
题目描述: 自己的提交: class Solution: def sequentialDigits(self, low: int, high: int) -> List[int]: l,h = ...
 - SQL Server 创建表
			
SQL Server 创建表 我们在上一节中完成了数据库的创建,在本节,我们要往这个新的数据库中加入点数据,要想将数据添加到数据库,我们就必须在数据库中添加一个表,接下来来看看具体的操作. 我们的数据 ...
 - .Net Core 使用 Swagger 提供API文档
			
1.运行环境 开发工具:Visual Studio 2017 JDK版本:.NET Core 2.0 项目管理工具:nuget 2.GITHUB地址 https://github.com/nbfujx ...
 - 【CF1256】Codeforces Round #598 (Div. 3) 【思维+贪心+DP】
			
https://codeforces.com/contest/1256 A:Payment Without Change[思维] 题意:给你a个价值n的物品和b个价值1的物品,问是否存在取物方案使得价 ...
 - 云平台(cloud platforms)
			
云平台:允许开发者们或是将写好的程序放在“云”里运行,或是使用“云”里提供的服务,或二者皆是的服务 转向云计算(cloud computing),是业界将要面临的一个重大改变.各种云平台(cloud ...
 - LOJ 6432 「PKUSC2018」真实排名——水题
			
题目:https://loj.ac/problem/6432 如果不选自己,设自己的值是 x ,需要让 “ a<x && 2*a>=x ” 的非 x 的值不被选:如果选自己 ...
 - [CSP-S模拟测试]:春思(数学)
			
蝶恋花·春景花褪残红青杏小.燕子飞时,绿水人家绕.枝上柳绵吹又少.天涯何处无芳草!墙里秋千墙外道.墙外行人,墙里佳人笑.笑渐不闻声渐悄.多情却被无情恼.(本词是伤春之作,写春景清新秀丽.同时,景中又有 ...
 - tomcat启动前端项目
			
前后端分离项目,前端使用vue,部署启动前端项目可以使用NodeJS,Nginx,Tomcat. *)使用Tomcat部署启动: 1.把vue项目build生成的dist包,放到Tomcat的weba ...
 - 【系统架构理论】一篇文章精通:Spring Cloud Netflix Eureka
			
是官方文档的总结 http://spring.io/projects/spring-cloud-netflix#overview 讲解基于2.0.2版本官方文档 https://cloud.sprin ...