Redis进阶(四):哨兵

为了解决主节点故障,需要人工操作切换主从的情况;因此需要一种方法可以自动化的切换:哨兵的引入大大改变这种情况。

哨兵的基本概念

自动切换主从节点

哨兵架构

1、当一个哨兵节点发现主节点挂了的时候,还需要其他节点也去检测一下这个主节点到底是不是真的挂了(防止误判)。

2、发现是真的挂了之后,哨兵 节点推举 一个leader之后,选一个slave作为新的主节点

3、挑选新的主节点之后,哨兵节点自动的将从节点slave no one 脱离主节点的控制,并且控制其他的从节点归附到这个新的主节点身上。

4、哨兵节点会自动通知客户端,告知新的主节点是谁,并且后续客户端进行写操作就是针对新的主节点了。

因此 redis 哨兵核心功能 : 1.监控 2.自动的故障转移 3.通知

搭建哨兵

准备工作(基于docker)

docker可以认为是一个轻量级的虚拟机:隔离环境,不吃硬件资源

docker-compose:管理一组docker容器

镜像:docker中的镜像和容器类似于 可执行程序 和 进程 的关系

镜像(Mirroring)是一种文件存储形式,一个磁盘上的数据在另一个磁盘上存在一个完全相同的副本即为镜像。

容器 (Container) 泛指任何可以用于容纳其它物品的工具,可以部分或完全封闭,被用于容纳、储存、运输物品。

在云原生技术中,容器就是将软件(镜像)打包成标准化单元,以用于开发、交付和部署。

  • 容器可以是镜像的一个实例
  • 镜像是文件,容器是进程
  • 镜像为静态,而容器可能为动态

镜像准备好之后,拉取的镜像里面包含了一个精简的Linux操作系统,并且上面安装了redis,基于镜像创建容器跑起来即可。

搭建redis哨兵环境

创建数据节点

修改配置文件:

java 复制代码
version: '3.7'
services:
 master:
  image: 'redis:5.0.9' //基于哪个镜像
  container_name: redis-master
  restart: always
  command: redis-server --appendonly yes
  ports: 
     - 6379:6379 //端口映射
 slave1:
  image: 'redis:5.0.9'
  container_name: redis-slave1
  restart: always
  command: redis-server --appendonly yes --slaveof redis-master 6379
  ports:
     - 6380:6379
 slave2:
  image: 'redis:5.0.9'
  container_name: redis-slave2
  restart: always
  command: redis-server --appendonly yes --slaveof redis-master 6379
  ports:
     - 6381:6379

redis -cli -p进行验证

创建哨兵节点

java 复制代码
version: '3.7'
services:
 sentinel1:
  image: 'redis:5.0.9'
  container_name: redis-sentinel-1
  restart: always
  command: redis-sentinel /etc/redis/sentinel.conf
  volumes:
   - ./sentinel1.conf:/etc/redis/sentinel.conf
  ports:
   - 26379:26379
 sentinel2:
  image: 'redis:5.0.9'
  container_name: redis-sentinel-2
  restart: always
  command: redis-sentinel /etc/redis/sentinel.conf
  volumes:
   - ./sentinel2.conf:/etc/redis/sentinel.conf
  ports:
   - 26380:26379
 sentinel3:
  image: 'redis:5.0.9'
  container_name: redis-sentinel-3
  restart: always
  command: redis-sentinel /etc/redis/sentinel.conf
  volumes:
   - ./sentinel3.conf:/etc/redis/sentinel.conf
  ports:
   - 26381:26379
networks:
 default:
  external:
   name: redis-data_default 

创建sentinel1.conf sentinel2.conf sentinel3.conf 三份⽂件的内容是完全相同的.

都放到 /root/redis-sentinel/ ⽬录中.

java 复制代码
bind 0.0.0.0
port 26379
sentinel monitor redis-master redis-master 6379 2
sentinel down-after-milliseconds redis-master 1000

启动哨兵节点:

java 复制代码
docker-compose up -d

但要注意的是,docker-compose启动多个容器:处于同一个局域网中,可以使这个容器相互访问,当时哨兵节点配置文件中的sentinel monitor注明的是另一个局域网(三个redis-server节点是一个局域网),并不能访问,

java 复制代码
docker network ls

列出当前docker中的局域网

修改配置文件即可达成修改局域网:

java 复制代码
networks:
 default:
  external:
   name: redis-data_default 

name的获取从 列出当前docker中的局域网(docker network ls) 获取到

查看日志

java 复制代码
docker-compose logs

重新选举

手动干掉主节点后观察日志:

确定主节点挂了之后,就需要选拔新的主节点

redis-master重启之后
java 复制代码
docker start redis-master

Redis主节点如果宕机,会把其中的⼀个从节点,提拔成主节点.

当之前的Redis主节点重启之后,这个主节点被加⼊到哨兵的监控中,但是只会被作为从节点使⽤.

主从切换的具体流程

1.主观下线

哨兵节点通过心跳包判定redis服务器是否正常工作,如果没有心跳包了,说明redis节点挂了,但是此时不能排除网络波动影响,只能单方面认为该节点挂了

2.客观下线

多个哨兵认为主节点挂了:认为挂了的哨兵节点数目达到法定票数,哨兵们就认为该主节点客观下线

3.要让多个哨兵节点选举一个leader,由这个leader负责选一个从节点作为新的主节点。

示例:

此时一号哨兵成为leader

每个哨兵只有一票,当哨兵1发现当前主节点客观下线之后,就立即给自己投一票,并且告诉了2,3哨兵节点,(当他们没有投票的时候,收到投票请求就会投出去)如果总的票数超过了哨兵总数的一半,选举完成(哨兵总数常设为奇数)

4.此时leader选举完毕,leader需要挑选一个从节点作为主节点:

a.优先级:每个redis数据节点都会在配置文件中,有一个优先级设置,slave-priority,优先级高的节点会win

b.offset 优先级相同比较offset,offset:从节点从主节点同步数据的进度,挑选offset大的节点作为主节点

c.run id 每个redis节点启动的时候随机生成的一串数字:此时选谁都行,随机挑一个。看run id 更小

5.新的主节点选好之后,leader会控制这个节点执行slave no one,成为master。并且控制其他节点执行slave of,让这些其他节点 "认主" 。

相关推荐
AntDreamer29 分钟前
在实际开发中,如何根据项目需求调整 RecyclerView 的缓存策略?
android·java·缓存·面试·性能优化·kotlin
失心疯_202330 分钟前
006.MySQL_查询数据
数据库·sql·mysql·关系型数据库·sqlyog·mysql教程·查询语句
环能jvav大师38 分钟前
基于R语言的统计分析基础:使用SQL语句操作数据集
开发语言·数据库·sql·数据分析·r语言·sqlite
骆晨学长1 小时前
基于springboot的智慧社区微信小程序
java·数据库·spring boot·后端·微信小程序·小程序
@月落1 小时前
alibaba获得店铺的所有商品 API接口
java·大数据·数据库·人工智能·学习
楠枬1 小时前
MySQL数据的增删改查(一)
数据库·mysql
goTsHgo1 小时前
从底层原理上解释 clickhouse 保证完全的幂等性
数据库·clickhouse
阿华的代码王国3 小时前
MySQL ------- 索引(B树B+树)
数据库·mysql
码爸3 小时前
flink 批量压缩redis集群 sink
大数据·redis·flink
Hello.Reader3 小时前
StarRocks实时分析数据库的基础与应用
大数据·数据库