星途物语 星途物语
首页
  • 随手记录
  • 故障处理
  • Nginx
  • MySQL
  • Ansible
  • Nexus
  • Tomcat
  • Docker
  • Zabbix
  • Prometheus
  • Git
  • GitLab
  • Jenkins
  • Kubernetes
  • Shell
  • Python
  • 圈圈空间
  • 做饭这件事
收藏站点
留言板
归档
GitHub (opens new window)

星途物语

尚记时,记之
首页
  • 随手记录
  • 故障处理
  • Nginx
  • MySQL
  • Ansible
  • Nexus
  • Tomcat
  • Docker
  • Zabbix
  • Prometheus
  • Git
  • GitLab
  • Jenkins
  • Kubernetes
  • Shell
  • Python
  • 圈圈空间
  • 做饭这件事
收藏站点
留言板
归档
GitHub (opens new window)
  • 随手记录

    • QPS优化记录
    • 阿里云SLB演示
    • DDOS预防
    • Linux内核优化
    • rsync同步守护进程
    • NFS文件同步
    • Tomcat升级
    • 编译安装mysql后添加到systemd管理
    • 防火墙笔记
    • python自动化巡检服务器
  • 故障处理

    • 处理防MIME攻击后出现的问题解决
  • MySQL学习笔记

    • MySQL5.7安装
    • MySQL常用操作语句
    • MySQL主从架构实施
    • MySQL主主架构实施
    • MySQL MHA高可用实施
    • MyCat读写分离
    • MySQL创建用户时的授权
    • MySQL备份
    • MySQL通配符
  • Nginx学习笔记

    • 状态码含义
    • 匹配优先级
    • Nginx常用操作
    • 添加第三方模块
    • 关于路径匹配
    • 转发和重写
    • 内置变量
    • Nginx配置文件结构
  • Tomcat学习笔记

    • 部署Tomcat
    • 修改发布目录
    • Tomcat调优
  • Redis学习笔记

    • 通过 tar.gz 包安装部署 redis
    • redis 配置文件
    • 哨兵集群
    • redis常用命令
    • 虚拟机安装 redis.tar.gz 遇到的问题
  • Ansible学习笔记

    • 部署和使用 ansible
    • ansible 自带的密码认证参数
    • 批量免密操作:批量分发公钥
    • 配置主机清单
    • ansible 小知识
    • 模块介绍
    • 剧本
    • 一键部署 rsync 环境
    • 批量安装一个tomcat
    • 批量安装一个nginx
    • 批量安装 zabbix-agent
  • Zabbix学习笔记

    • 部署 zabbix 服务端、客户端
    • 自定义监控
    • 触发器
    • 监控项类型
    • 简单检查模式
    • zabbix web 界面结构信息
    • 邮件报警
    • 微信报警
    • snmp 监控网络设备
    • 部署 zabbix 服务端、客户端
    • jmx 监控 java 应用
    • ipmi 监控硬件
    • 自动化注册
    • 监控项的主要项和相关项
    • percona 监控 mysql
  • Git学习笔记

    • 配置 git
    • 常用命令
  • GitLab学习笔记

    • 环境准备
    • 安装 gitlab
    • gitlab 忘记 root 管理员密码的处理办法
  • Jenkins学习笔记

    • 安装部署
    • jenkins 使用脚本完成项目构建
    • jenkins 自动构建最新项目
    • 将 jenkins 自动部署的结果返回给 gitlab
    • jenkins 上线 java 项目
    • jenkins pipeline
  • Docker学习笔记

    • 安装 docker
    • 配置 docker 源
    • docker 中的常见名词
    • 镜像管理命令
    • 容器管理命令
    • 创建容器
    • 数据卷
    • docker network
    • 搭建 LNMP
    • Dockerfile
    • Dockerfile 搭建 tomcat
    • docker 镜像磁盘扩容
    • docker composer
    • Harbor 私有镜像仓库
    • docker 面试题
    • docker desktop 运行时与虚拟机冲突
    • docker离线安装
  • Nexus学习笔记
  • Prometheus学习笔记

    • 核心组件
    • 工作原理
    • 安装和配置
    • 启动 Prometheus
    • PromQL 使用
    • 数据模型
    • Exporter
    • 演示服务
    • Grafana 数据可视化
    • Prometheus 告警
  • Kubernetes学习笔记

    • K8S的介绍
    • K8S集群环境的搭建
    • K8S资源管理
    • K8S的实战入门
  • 运维
  • Redis学习笔记
星途物语
2025-01-01

哨兵集群

Redis哨兵是一种用于监控主从结构的高可用性方案

当主节点发生故障时,哨兵会自动将某个从节点提升为新的主节点,并通知其他从节点更新主节点信息

哨兵主要有三大功能:

  1. 监控:监控Redis实例是否正常运行
  2. 自动故障转移:当主节点出现问题时,自动将从节点提升为主节点
  3. 通知和协调:通过发布和订阅模式,将配置变更通知给客户端

配置高可用哨兵

主节点确定有如下配置:

bind 0.0.0.0
protected-mode yes
port 6379
requirepass 123456
daemonize yes
1
2
3
4
5

从节点的配置需要指定主节点:

bind 0.0.0.0
protected-mode yes
port 6379
slaveof 10.0.0.22 6379
requirepass 123456
masterauth 123456
daemonize yes
1
2
3
4
5
6
7

创建哨兵配置文件:sentinel.conf

echo "" > sentinel.conf

cat > sentinel.conf << EOF
port 26379
daemonize yes
protected-mode no
sentinel myid 29353d6dffaedf2df12e190357ea87454415c1ee
sentinel monitor mymaster 10.0.0.22 6379 2
sentinel down-after-milliseconds mymaster 5000
sentinel failover-timeout mymaster 10000
sentinel auth-pass mymaster 123456
EOF
1
2
3
4
5
6
7
8
9
10

启动哨兵:redis-sentinel ./sentinel.conf

image-20240829174202426

成功启动,有个小错误看一下,根据实际情况修改

WARNING: The TCP backlog setting of 511 cannot be enforced because /proc/sys/net/core/somaxconn is set to the lower value of 128.

这个警告表明 Redis 的 TCP backlog 设置为 511,但系统允许的最大值(somaxconn)为 128

somaxconn 的默认值通常较小,增加它可以提高系统对大量并发连接的处理能力,但过大的值也可能导致系统资源耗尽

vim /etc/sysctl.conf

net.core.somaxconn = 511

sysctl -p

验证哨兵集群

在主 redis 验证状态

image-20240829195814668

在从 redis 验证状态

image-20240829195917738

在主节点设置一个键值,在从节点测试是否能查看

image-20240829200039426 image-20240829200054746

模拟故障转移,停止主 redis,查看 sentinel 日志信息

# 哨兵检测到原主节点 10.0.0.22:6379 出现了故障,并将主节点切换为 10.0.0.23:6379。这意味着 10.0.0.23 已被提升为新的主节点
127780:X 29 Aug 19:36:27.056 # +switch-master mymaster 10.0.0.22 6379 10.0.0.23 6379
# 原来的主节点 10.0.0.22 现在被重新配置为从节点,开始跟随新的主节点 10.0.0.23
127780:X 29 Aug 19:36:27.056 * +slave slave 10.0.0.22:6379 10.0.0.22 6379 @ mymaster 10.0.0.23 6379
# 哨兵检测到从节点 10.0.0.22:6379 出现了故障,进入了 sdown(subjectively down)状态,这意味着哨兵无法联系到该从节点
127780:X 29 Aug 19:36:32.091 # +sdown slave 10.0.0.22:6379 10.0.0.22 6379 @ mymaster 10.0.0.23 6379
1
2
3
4
5
6

开启之前的主节点

# 哨兵系统检测到从节点 10.0.0.22:6379 已经恢复正常,并从 sdown 状态(主观下线)中退出
# 意味着从节点 10.0.0.22:6379 已经恢复正常并重新与主节点同步
127780:X 29 Aug 19:39:37.269 # -sdown slave 10.0.0.22:6379 10.0.0.22 6379 @ mymaster 10.0.0.23 6379
1
2
3
#Redis
redis 配置文件
redis常用命令

← redis 配置文件 redis常用命令→

Theme by Vdoing | Copyright © 2025-2025 | 鄂ICP备2024086820号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式