返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >Redis Sentinel的基本搭建
  • 378
分享到

Redis Sentinel的基本搭建

2024-04-02 19:04:59 378人浏览 安东尼
摘要

目录Redis Sentinel的概念01 主从复制问题02 Redis Sentinel的高可用机制03 sentinel部署Redis Sentinel的概念   &n

Redis Sentinel的概念

   我们知道Redis主从模式下,一旦主节点由于故障不能提供服务,需要人工将从节点晋升为主节点,同时还要通知应用方更新主节点的地址。然后在很多应用场景下这种故障处理的方式是无法接受的,应用程序需要实时感知当前的可用节点。为了解决这个问题,Redis Sentinel应运而生,也称之为"哨兵"。

   介绍sentinel之前,先来了解几个redis的概念,

主节点master:Redis进程,主服务

从节点slave:redis进程,从服务

Redis数据节点:主节点和从节点

Sentinel节点:监控Redis数据节点,独立的sentinel进程

Sentinel节点集合:若干Sentinel节点的抽象组合,若干sentinel节点进程

Redis Sentinel:Redis高可用实现方案,sentinel节点集合和redis数据节点进程

01 主从复制问题

前面的文章中我们讲述了主从复制,可以将从节点作为主节点的灾备节点,今天我们来看主从复制带来的问题:

1、一旦主节点发生故障,从节点晋升为主节点的过程和应用调整新主节点的过程,都需要人为干预

2、主节点的写能力容易受到单机的限制

3、主节点的存储能力容易受到单机的限制

   一种常见的方法是使用脚本来触发主从节点的角色切换,例如在一个一主两从的结构中,假设主节点master,从节点slave1,slave2,我们来看故障发生时架构的状态:

1、主节点master故障,客户端连接失败,两个从节点复制失败

2、选择一个主节点slave1,对其执行slave of no one命令使其成为主节点master2

3、更新应用程序连接的节点为slave1的IP地址

4、slave2以slave1为新的主节点,复制slave1上的命令

5、待原来的master恢复之后,让它成为slave1的从节点。

上述过程可以做成自动化的过程,但是需要考虑三点:a、要确保判断节点不可达的机制健全,否则容易出现误判断情况

b、如果有多个从节点,如果保证只有一个从节点被晋升为主节点是个关键的问题

c、通知客户端新的主节点的机制是否足够健壮

02 Redis Sentinel的高可用机制

   Sentinel能够自动完成故障发现和故障转移,并及时通知应用方。这是它的核心价值所在。

   Redis Sentinel是一个分布式架构,其中包含若干个Sentinel和若干个Redis数据节点,每个Sentinel节点会对数据节点和其余Sentinel节点进行监控,当它发现节点不可达时,会对节点做下线表示。如果被标识的是主节点,它还会和其他的sentinel进行协商,当大多数sentinel节点都认为主节点不可达时,他们会选举出来一个sentinel节点来实现故障自动转移,同时会将这个变化通知给Redis应用方,整个过程是自动的,不需要人工介入。

Redis Sentinel与Redis主从复制模式只是多了若干个sentinel节点,并没有对redis节点做特殊处理,这是很多redis开发运维人员容易混淆的地方。

二者架构图如下:

在整个主服务故障到重新选择主服务的过程中,sentinel主要干如下几件事情:

1、监控,sentinel节点会定期检测redis数据节点,其余sentinel节点是否可达

2、通知,sentinel节点会将故障转移的结果通知给应用方。

3、主节点故障转移:实现从节点晋升为主节点并维护后续正确的主从关系

4、配置提供者:在redis sentinel结构中,客户端在初始化的时候连接的是sentinel节点集合,从中获取主节点信息

   上面的架构图中不难发现sentinel也是多个的,这样的好处有两个:

1、可以保证sentinel的健壮性,一个sentinel挂了,不影响整个集群的功能。

2、对于节点的故障判断是多个sentinel同时判断出来的,有效的防止了误判

    sentinel节点本身其实就是独立的redis节点,只不过它们不存处数据,只支持部分命令。

    接下来,我们来看sentinel的部署和配置文件内容。

03 sentinel部署

    sentinel部署之前,需要先有master和两个slave的一主两从架构:


127.0.0.1:6379> info replication
# Replication
role:master
connected_slaves:2
slave0:ip=127.0.0.1,port=6380,state=online,offset=169,lag=1
slave1:ip=127.0.0.1,port=6381,state=online,offset=169,lag=1
master_repl_offset:183
repl_backlog_active:1
repl_backlog_size:1048576
repl_backlog_first_byte_offset:2
repl_backlog_histlen:182

  sentinel的部署配置文件:


[root@VM_48_10_Centos redis]# cat redis-sentinel-26379.conf 
port 26379
daemonize yes
logfile "26379.log"
dir "/usr/local/redis-3.0.7"
sentinel monitor mymaster 127.0.0.1 6379 2

  其中,sentinel monitor mymaster代表sentinel要监控主节点6379,2代表判断主节点失败至少需要2个sentinel节点同意。

  其余两个sentinel的配置文件和这个大同小异,只需要修改对应端口和日志文件即可。sentinel启动命令如下:


[root@VM_48_10_centos redis]# redis-sentinel redis-sentinel-26379.conf &
[1] 7311
[root@VM_48_10_centos redis]# redis-sentinel redis-sentinel-26380.conf &
[1] 7366
[root@VM_48_10_centos redis]# redis-sentinel redis-sentinel-26381.conf &
[2] 7380
[root@VM_48_10_centos redis]# 
[root@VM_48_10_centos redis]# ps -ef|grep sentinel
root      7312     1  0 22:51 ?        00:00:00 redis-sentinel *:26379 [sentinel]
root      7367     1  0 22:52 ?        00:00:00 redis-sentinel *:26380 [sentinel]
root      7381     1  0 22:52 ?        00:00:00 redis-sentinel *:26381 [sentinel]
root      7405  5850  0 22:52 pts/7    00:00:00 grep --color=auto sentinel

此时,重新查看26379这个sentinel的配置文件,会发现里面多了一些内容:


[root@VM_48_10_centos redis]# cat redis-sentinel-26379.conf 
port 26379
daemonize yes
logfile "26379.log"
dir "/usr/local/redis-3.0.7"
sentinel monitor mymaster 127.0.0.1 6379 2
sentinel config-epoch mymaster 0
sentinel leader-epoch mymaster 0
sentinel known-slave mymaster 127.0.0.1 6380
# Generated by CONFIG REWRITE
sentinel known-slave mymaster 127.0.0.1 6381
sentinel known-sentinel mymaster 127.0.0.1 26381 0a2c77616ef88282fa12ef7c8aca142a2473cd5a
sentinel known-sentinel mymaster 127.0.0.1 26380 3ad6460bf5f4b01f277fdce3aa423D596993eec5
sentinel current-epoch 0

   可以发现,sentinel之间已经进行了交互,并写入了配置文件中一些已经获取到的内容。

使用命令info sentinel查看当前sentinel集群的信息:


[root@VM_48_10_centos redis]# redis-cli -h 127.0.0.1 -p 26379 info sentinel
# Sentinel
sentinel_masters:1
sentinel_tilt:0
sentinel_running_scripts:0
sentinel_scripts_queue_length:0
master0:name=mymaster,status=ok,address=127.0.0.1:6379,slaves=2,sentinels=3

以上就是Redis Sentinel的使用的详细内容,更多关于Redis Sentinel的资料请关注编程网其它相关文章!

--结束END--

本文标题: Redis Sentinel的基本搭建

本文链接: https://lsjlt.com/news/122604.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Redis Sentinel的基本搭建
    目录Redis Sentinel的概念01 主从复制问题02 Redis Sentinel的高可用机制03 sentinel部署Redis Sentinel的概念   &n...
    99+
    2024-04-02
  • redis如何搭建sentinel哨兵机制
    redis如何搭建sentinel哨兵机制?相信大部分人都还没学会这个技能,为了让大家学会,给大家总结了以下内容,话不多说,一起往下看吧。1.redis主从创建(一主两从):在从节点上执行:slaveof ...
    99+
    2024-04-02
  • 玩转Redis搭建集群之Sentinel详解
    前言 Redis作为内存数据库,需要具备高可用的特点,不然如果服务器宕机,还在内存里的数据就会丢失。我们最常用的高可用方法就是搭建集群,master机器挂了,可以让slave机器顶上,继续提供服务。但是Re...
    99+
    2024-04-02
  • Redis Sentinel实现哨兵模式搭建小结
    Redis哨兵模式,用现在流行的话可以说就是一个“哨兵机器人”,给“哨兵机器人”进行相应的配置之后,这个"机器人"可以7*24小时工作,它能能够自动帮助你做一些事情,如监控,提醒,自动处理故障等。 Redi...
    99+
    2024-04-02
  • redis创建sentinel参考
    1.redis主从创建(一主两从):在从节点上执行:slaveof 192.168.56.201 6379  #master的ip地址和端口也可以在配置文件中配置:slaveof 192.168....
    99+
    2024-04-02
  • 如何进行Redis 6.X Sentinel哨兵集群搭建
    如何进行Redis 6.X Sentinel哨兵集群搭建,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。码哥带大家完成在 CentOS 7 中安装 Redis 6...
    99+
    2023-06-15
  • 分布式Redis Cluster集群搭建与Redis基本用法
    目录Redis 集群搭建Redis 是啥集群(Cluster)Redis Cluster 说明Redis Cluster 节点Redis Cluster 集群模式不能保证一致性创建和...
    99+
    2024-04-02
  • 基于Sentinel的Redis高可用方案
       数据存储我们在应用设计过程中非常重要的一部分,无论是关系型数据库,还是Redis、MongoDB等非关系型数据库,都有很多的高可用方案,还有一些针对不同业务设计的中间件,使其性能更...
    99+
    2024-04-02
  • Linux的基本开发环境搭建
    0.安装命令小技巧 1、DEB软件安装 安装命令 sudo dpkg -i xxx.deb 2、安装过程中可能会报缺少依赖的错,执行下面命令自动安装依赖 sudo apt-get install -f 3、再次执行安装命令 sudo ...
    99+
    2023-01-31
    环境 Linux
  • Redis Sentinel的使用方法
    这期内容当中小编将会给大家带来有关Redis Sentinel的使用方法,以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Redis Sentinel 是一个分布式架构(这里的分布式是指:...
    99+
    2024-04-02
  • Redis的哨兵(sentinel)(概念)
    Redis的哨兵(sentinel)       redis的sentinel系统用于管理多个redis服务器实例(instance)。        哨兵适用于非集群结构的redis环境,比如:redis...
    99+
    2024-04-02
  • 基于Docker搭建Redis主从集群的实现
    目录1、拉取 Redis 镜像2、创建 6 个 Redis 容器3、启动 Redis 容器4、组建 Redis 集群5、关于Redis集群搭建最近陆陆续续有不少园友加我好友咨询 re...
    99+
    2024-04-02
  • redis的搭建过程
    本篇内容介绍了“redis的搭建过程”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!redis官网:http...
    99+
    2024-04-02
  • 本地搭建svn服务器及TortoiseSVN的基本使用
    文章目录 一、首先准备三个软件:二、安装及使用1.VisualSVN-Server-5.1.1-x64.msi(svn服务端)一、创建新的存储库二、创建用户Users三、添加一个组—groups四、修改一下项目的配置文件五、本地访问...
    99+
    2023-08-30
    服务器 svn 运维
  • redis集群搭建
    Redis 5.0之后版本的高可用集群搭建 Redis系统介绍: Redis的基础介绍与安装使用步骤:https://www.jianshu.com/p/2a23257af57b Redis的基础数据结构与使用:https...
    99+
    2019-03-23
    redis集群搭建
  • Redis中的Sentinel机制怎么用
    这篇文章将为大家详细讲解有关Redis中的Sentinel机制怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1. 概述Redis-Sentinel是Redis官方推...
    99+
    2024-04-02
  • React-Native 环境搭建和基本介绍
    环境搭建准备 1.环境搭建 React Native中文网 2.开发工具 前端开发软件:Visual Studio Code 移动端开发软件:Xcode、Android Studio...
    99+
    2024-04-02
  • pbootcms基本使用方法,搭建教程
    上传到自己的主机,输入域名打开,会出现授权的页面,直接到pbootcms的官网进行授权(免费)。 点击pbootcms官网进入网站     2、登录后台,登录方式:你的域名/admin.php 账号:admin 密码:admin 3、...
    99+
    2023-09-09
    php
  • Docker compose搭建ELK服务基本使用
    目录概述docker-compose 基本使用最后概述 使用的是docker-compose方法安装elk组件,对这部分的内容进行一个知识上的补充,使用docker-compose...
    99+
    2023-03-23
    Docker compose搭建ELK Docker compose
  • redis基本配置
    1.下载编译安装cd /usr/srcwget http://download.redis.io/releases/redis-3.2.3.tar.gztar -xf redis-3.2...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作