当前位置: 首页 > news >正文

(分布式缓存)Redis哨兵

对应的教程视频:

高级篇Day3-03-Redis哨兵_哔哩哔哩_bilibili

目录:

  • 哨兵的作用和原理
  • 搭建哨兵集群
  • RedisTemplate的哨兵模式

一、哨兵的作用和原理

 

 

 

 

 

二、搭建哨兵集群

1.集群结构

这里我们搭建一个三节点形成的Sentinel集群,来监管之前的Redis主从集群。如图:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-MOzScJfs-1662037549415)(assets/image-20210701215227018.png)]

三个sentinel实例信息如下:

节点IPPORT
s1192.168.150.10127001
s2192.168.150.10127002
s3192.168.150.10127003

2.准备实例和配置

要在同一台虚拟机开启3个实例,必须准备三份不同的配置文件和目录,配置文件所在目录也就是工作目录。

我们创建三个文件夹,名字分别叫s1、s2、s3:

# 进入/tmp目录
cd /tmp
# 创建目录
mkdir s1 s2 s3

如图:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-smeM4g2V-1662037549418)(assets/image-20210701215534714.png)]

然后我们在s1目录创建一个sentinel.conf文件,添加下面的内容:

port 27001
sentinel announce-ip 192.168.150.101
sentinel monitor mymaster 192.168.150.101 7001 2
sentinel down-after-milliseconds mymaster 5000
sentinel failover-timeout mymaster 60000
dir "/tmp/s1"

解读:

  • port 27001:是当前sentinel实例的端口
  • sentinel monitor mymaster 192.168.150.101 7001 2:指定主节点信息
    • mymaster:主节点名称,自定义,任意写
    • 192.168.150.101 7001:主节点的ip和端口
    • 2:选举master时的quorum值

然后将s1/sentinel.conf文件拷贝到s2、s3两个目录中(在/tmp目录执行下列命令):

# 方式一:逐个拷贝
cp s1/sentinel.conf s2
cp s1/sentinel.conf s3
# 方式二:管道组合命令,一键拷贝
echo s2 s3 | xargs -t -n 1 cp s1/sentinel.conf

修改s2、s3两个文件夹内的配置文件,将端口分别修改为27002、27003:

sed -i -e 's/27001/27002/g' -e 's/s1/s2/g' s2/sentinel.conf
sed -i -e 's/27001/27003/g' -e 's/s1/s3/g' s3/sentinel.conf

3.启动

为了方便查看日志,我们打开3个ssh窗口,分别启动3个redis实例,启动命令:

# 第1个
redis-sentinel s1/sentinel.conf
# 第2个
redis-sentinel s2/sentinel.conf
# 第3个
redis-sentinel s3/sentinel.conf

启动后:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-CrsAz2Dy-1662037549420)(assets/image-20210701220714104.png)]

4.测试

尝试让master节点7001宕机,查看sentinel日志:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qr3runAh-1662037549420)(assets/image-20210701222857997.png)]

查看7003的日志:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-OIkdnoom-1662037549421)(assets/image-20210701223025709.png)]

查看7002的日志:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-erHnH2jJ-1662037549425)(assets/image-20210701223131264.png)]

三、RedisTemplate的哨兵模式

Sentinel集群监管下的Redis主从集群,其节点会因为自动故障转移而发生变化,Redis的客户端必须感知这种变化,及时更新连接信息。SpringRedisTemplate底层利用lettuce实现了节点的感知和自动切换。

首先,我们引入课前资料提供的Demo工程:

 

 

相关文章:

  • 全网最详细安装 IntelliJ IDEA (原理+方法)不看别后悔
  • idea(2021版本)Springboot项目热部署
  • Centos7 SSH登陆慢的解决办法
  • Matlab:Matlab编程语言学习之向量化编程的简介、技巧总结案例应用之详细攻略
  • 大厂C++协作框架(基辅)技术原理
  • 【云原生】基于Kubernetes开发的阿里云ACK之存储管理
  • 【Java多线程】必须要了解的基本概念
  • 走进音视频的世界——Opus编解码协议
  • SaaS vs 低代码,谁在成为中国产业服务的楔子?
  • Redis实战精讲(3)
  • Flink(二)
  • 全息干涉图补零尺寸与三种重构方法重建像间的关系研究
  • Vue2(十三):路由的使用及注意点、嵌套路由、路由的query和params参数、props配置
  • 如何增强 ABAP 系统,允许开发人员给 ABAP 对象设置标签,方便快速检索
  • 【Python】面向对象 -没有对象?new一个吧
  • 【面试系列】之二:关于js原型
  • django开发-定时任务的使用
  • Idea+maven+scala构建包并在spark on yarn 运行
  • javascript 哈希表
  • jQuery(一)
  • Kibana配置logstash,报表一体化
  • k个最大的数及变种小结
  • Linux各目录及每个目录的详细介绍
  • mysql_config not found
  • Otto开发初探——微服务依赖管理新利器
  • SpringCloud集成分布式事务LCN (一)
  • 爱情 北京女病人
  • 码农张的Bug人生 - 见面之礼
  • 前端每日实战 2018 年 7 月份项目汇总(共 29 个项目)
  • 实战:基于Spring Boot快速开发RESTful风格API接口
  • 以太坊客户端Geth命令参数详解
  • 3月27日云栖精选夜读 | 从 “城市大脑”实践,瞭望未来城市源起 ...
  • mysql 慢查询分析工具:pt-query-digest 在mac 上的安装使用 ...
  • ​LeetCode解法汇总2808. 使循环数组所有元素相等的最少秒数
  • ​Linux Ubuntu环境下使用docker构建spark运行环境(超级详细)
  • #define与typedef区别
  • #图像处理
  • %check_box% in rails :coditions={:has_many , :through}
  • (1)bark-ml
  • (ctrl.obj) : error LNK2038: 检测到“RuntimeLibrary”的不匹配项: 值“MDd_DynamicDebug”不匹配值“
  • (C语言)球球大作战
  • (java版)排序算法----【冒泡,选择,插入,希尔,快速排序,归并排序,基数排序】超详细~~
  • (二十一)devops持续集成开发——使用jenkins的Docker Pipeline插件完成docker项目的pipeline流水线发布
  • (附源码)计算机毕业设计SSM智能化管理的仓库管理
  • (排序详解之 堆排序)
  • (强烈推荐)移动端音视频从零到上手(上)
  • (三)Hyperledger Fabric 1.1安装部署-chaincode测试
  • (一)C语言之入门:使用Visual Studio Community 2022运行hello world
  • (一一四)第九章编程练习
  • (转)scrum常见工具列表
  • (转)总结使用Unity 3D优化游戏运行性能的经验
  • .dat文件写入byte类型数组_用Python从Abaqus导出txt、dat数据
  • .NET Framework 4.6.2改进了WPF和安全性
  • .net on S60 ---- Net60 1.1发布 支持VS2008以及新的特性
  • .Net 高效开发之不可错过的实用工具