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

三台 Centos7.9 中 Docker 部署 Redis 哨兵模式

三台 Centos7.9 中 Docker 部署 Redis 哨兵模式

  • 1. 环境规划
  • 2. 配置 Docker Compose
  • 3. 配置 Redis 密码和持久化
  • 4. 配置哨兵
  • 5. 启动服务
  • 6. 验证 Redis 哨兵模式
  • 7. 注意事项

1. 环境规划

三台服务器的角色分配如下:

IP Address容器端口角色
192.168.15.128redis-master6379主节点
192.168.15.129redis-slave16379从节点
192.168.15.130redis-slave26379从节点
192.168.15.128sentinel126379哨兵节点
192.168.15.129sentinel226379哨兵节点
192.168.15.130sentinel326379哨兵节点

Redis 主节点和哨兵将在同一台服务器上运行。

mkdir ~/redis-clusterr
# 这一步自选,想放哪里放哪里

2. 配置 Docker Compose

在每台服务器上创建自己的 docker-compose.yml 文件。

192.168.15.128 - docker-compose.yml

version: '3.9'
services:
  redis-master:
    image: redis:6.0
    container_name: redis-master
    restart: always
    ports:
      - "6379:6379"
    volumes:
      - ./data:/data
      - ./redis.conf:/usr/local/etc/redis/redis.conf
    command: ["redis-server", "/usr/local/etc/redis/redis.conf"]
    networks:
      - redis-network

  sentinel1:
    image: redis:6.0
    container_name: redis-sentinel1
    restart: always
    ports:
      - "26379:26379"
    networks:
      - redis-network
    volumes:
      - ./sentinel1.conf:/usr/local/etc/sentinel.conf
    command: ["redis-sentinel", "/usr/local/etc/sentinel.conf"]

networks:
  redis-network:
    driver: bridge

192.168.15.129 - docker-compose.yml

version: '3.9'
services:
  redis-slave1:
    image: redis:6.0
    container_name: redis-slave1
    restart: always
    ports:
      - "6379:6379"
    volumes:
      - ./data:/data
      - ./redis.conf:/usr/local/etc/redis/redis.conf
    command: ["redis-server", "/usr/local/etc/redis/redis.conf"]
    networks:
      - redis-network

  sentinel2:
    image: redis:6.0
    container_name: redis-sentinel2
    restart: always
    ports:
      - "26379:26379"
    networks:
      - redis-network
    volumes:
      - ./sentinel2.conf:/usr/local/etc/sentinel.conf
    command: ["redis-sentinel", "/usr/local/etc/sentinel.conf"]

networks:
  redis-network:
    driver: bridge

192.168.15.130 - docker-compose.yml

version: '3.9'
services:
  redis-slave2:
    image: redis:6.0
    container_name: redis-slave2
    restart: always
    ports:
      - "6379:6379"
    volumes:
      - ./data:/data
      - ./redis.conf:/usr/local/etc/redis/redis.conf
    command: ["redis-server", "/usr/local/etc/redis/redis.conf"]
    networks:
      - redis-network

  sentinel3:
    image: redis:6.0
    container_name: redis-sentinel3
    restart: always
    ports:
      - "26379:26379"
    networks:
      - redis-network
    volumes:
      - ./sentinel3.conf:/usr/local/etc/sentinel.conf
    command: ["redis-sentinel", "/usr/local/etc/sentinel.conf"]

networks:
  redis-network:
    driver: bridge


3. 配置 Redis 密码和持久化

在每个服务器上创建 redis.conf 文件,内容如下。

redis.conf (适用于主节点)

bind 0.0.0.0
protected-mode yes
port 6379
requirepass your_master_password
masterauth your_master_password
appendonly yes
dir /data

redis.conf (适用于从节点)

bind 0.0.0.0
protected-mode yes
port 6379
requirepass your_slave_password
masterauth your_master_password
replicaof 192.168.15.128 6379
appendonly yes
dir /data

requirepass:设置访问实例的密码。
masterauth:从节点用此密码认证主节点。
appendonly:启用数据持久化。

4. 配置哨兵

更新各台服务器的 sentinelX.conf 文件,确保哨兵与 Redis 实例的密码匹配:

sentinelX.conf

port 26379
sentinel monitor mymaster 192.168.15.128 6379 2
sentinel auth-pass mymaster your_master_password
sentinel down-after-milliseconds mymaster 5000
sentinel failover-timeout mymaster 10000
sentinel parallel-syncs mymaster 1

sentinel auth-pass mymaster your_master_password:为哨兵提供与 Redis 主节点通信时使用的密码。

  • 192.168.15.128: Redis 主节点的 IP 地址。
  • 2: 最少票数要求,3 个哨兵中需要至少 2 个同意切换主节点。

5. 启动服务

在每台服务器的对应目录运行:

docker-compose up -d

验证所有容器是否正常运行:

docker ps

6. 验证 Redis 哨兵模式

检查哨兵状态: 登录任意一个哨兵容器:

docker exec -it redis-sentinel1 redis-cli -p 26379

执行命令:

SENTINEL masters

SENTINEL slaves mymaster

模拟故障转移: 在主节点服务器停止主节点容器:


docker stop redis-master

查看日志确认哨兵是否选出新的主节点。

重新加入原主节点: 启动原主节点并手动设置为从节点:

docker start redis-master

docker exec -it redis-master redis-cli

slaveof NEW_MASTER_IP 6379

7. 注意事项

  • 端口防火墙:确保 6379 和 26379 端口在三台服务器之间互通。
  • 哨兵数量:建议使用奇数个哨兵以避免投票僵局。

完成以上步骤后,在 192.168.15.128 - 192.168.15.130 即可完成部署 Redis 哨兵模式。


http://www.kler.cn/a/509848.html

相关文章:

  • docker 基础语法学习,K8s基础语法学习,零基础学习
  • 代码随想录算法训练营第三十五天-动态规划-01背包(二维)
  • ZooKeeper 核心知识全解析:架构、角色、节点与应用
  • 【Vim Masterclass 笔记16】S07L32 + L33:同步练习09 —— 掌握 Vim 宏操作的六个典型案例(含点评课内容)
  • python——句柄
  • 将图像输入批次扁平化为CNN
  • 每日十题八股-2025年1月18日
  • VScode侧边栏左下角,没有NPM脚本,如何打开???
  • 代码随想录刷题day11|(链表篇)206.翻转链表
  • 20250118在excel中使用公式的时候如何直接拖拽全部到最后
  • ubuntu安全配置基线
  • 蓝桥杯训练—字符串对比
  • Git代码管理工具 — 5 GitHub远程仓库
  • 将.ext4文件挂载在ubuntu系统本地的步骤和方法
  • Redis 部署模式
  • Pandas库的常用内容归纳
  • [LeetCode] 链表完整版 — 虚拟头结点 | 基本操作 | 双指针法 | 递归
  • 安路FPGA开发工具TD:问题解决办法 及 Tips 总结
  • 鲍厚霖:引领AI广告创新,搭建中美合作桥梁
  • Python 的 WebSocket 实现详解
  • mysql 创建临时表报错
  • Spring boot框架下的RocketMQ消息中间件
  • 解析Three.js中几何体是如何构建的--BufferGeometry(四)
  • PG vs MySQL mvcc机制实现的异同
  • NodeJS | 搭建本地/公网服务器 live-server 的使用与安装
  • RabbitMQ基础篇