以下是使用 Redis 源码 tar 包在三台机器上安装 Redis 哨兵模式(Sentinel)的详细步骤,采用原生安装方式(非 Docker):
环境准备
- 三台 CentOS/Ubuntu 服务器 (假设 IP 如下):
- node1: 192.168.1.10 (主节点)
- node2: 192.168.1.11 (从节点)
- node3: 192.168.1.12 (从节点)
 
- Redis 版本:7.0.12(以最新稳定版为例)
- 端口规划 :
- Redis: 6379
- Sentinel: 26379
 
1. 在所有节点安装 Redis
(1)安装依赖
            
            
              bash
              
              
            
          
          # CentOS
yum install -y gcc make tcl
# Ubuntu
apt-get update && apt-get install -y build-essential tcl(2)下载并编译 Redis
            
            
              bash
              
              
            
          
          wget https://download.redis.io/releases/redis-7.0.12.tar.gz
tar xzf redis-7.0.12.tar.gz
cd redis-7.0.12
make && make install(3)创建配置文件目录
            
            
              bash
              
              
            
          
          mkdir -p /etc/redis /var/lib/redis /var/log/redis2. 配置主节点(node1)
(1)编辑 Redis 配置文件
            
            
              bash
              
              
            
          
          vim /etc/redis/redis.conf关键配置:
            
            
              ini
              
              
            
          
          bind 0.0.0.0
port 6379
daemonize yes
pidfile /var/run/redis_6379.pid
dir /var/lib/redis
appendonly yes
requirepass yourpassword  # 设置密码(可选)
masterauth yourpassword   # 如果设置了密码,从节点需要此项(2)启动 Redis
            
            
              bash
              
              
            
          
          redis-server /etc/redis/redis.conf3. 配置从节点(node2 和 node3)
(1)编辑 Redis 配置文件
            
            
              bash
              
              
            
          
          vim /etc/redis/redis.conf额外添加:
            
            
              ini
              
              
            
          
          replicaof 192.168.1.10 6379  # 指向主节点
masterauth yourpassword      # 如果主节点有密码(2)启动 Redis
            
            
              bash
              
              
            
          
          redis-server /etc/redis/redis.conf4. 配置 Sentinel(所有节点)
(1)编辑 Sentinel 配置文件
            
            
              bash
              
              
            
          
          vim /etc/redis/sentinel.conf内容如下:
            
            
              ini
              
              
            
          
          port 26379
daemonize yes
sentinel monitor mymaster 192.168.1.10 6379 2
sentinel down-after-milliseconds mymaster 5000
sentinel failover-timeout mymaster 10000
sentinel auth-pass mymaster yourpassword  # 如果主节点有密码(2)启动 Sentinel
            
            
              bash
              
              
            
          
          redis-sentinel /etc/redis/sentinel.conf5. 验证集群
(1)检查主从复制
            
            
              bash
              
              
            
          
          # 在主节点执行
redis-cli info replication输出应显示:
role:master
connected_slaves:2
slave0:ip=192.168.1.11,port=6379,state=online
slave1:ip=192.168.1.12,port=6379,state=online(2)测试 Sentinel 故障转移
            
            
              bash
              
              
            
          
          # 手动关闭主节点 Redis
redis-cli -h 192.168.1.10 shutdown
# 查看 Sentinel 选举结果
redis-cli -p 26379 sentinel get-master-addr-by-name mymaster约 10 秒后应返回新的主节点 IP。
6. 设置开机自启(所有节点)
(1)创建 systemd 服务文件
            
            
              bash
              
              
            
          
          vim /etc/systemd/system/redis.service内容:
            
            
              ini
              
              
            
          
          [Unit]
Description=Redis
After=network.target
[Service]
Type=forking
ExecStart=/usr/local/bin/redis-server /etc/redis/redis.conf
ExecStop=/usr/local/bin/redis-cli shutdown
Restart=always
[Install]
WantedBy=multi-user.target(2)启动服务
            
            
              bash
              
              
            
          
          systemctl daemon-reload
systemctl enable redis
systemctl start redis关键配置说明
| 参数 | 作用 | 
|---|---|
| sentinel monitor mymaster... | 指定监控的主节点, 2表示需要 2 个 Sentinel 同意才触发故障转移 | 
| down-after-milliseconds 5000 | 5 秒无响应判定节点宕机 | 
| replicaof | 从节点需配置此项指向主节点 | 
| requirepass/masterauth | 如果启用密码认证,主从和 Sentinel 需一致 | 
常见问题解决
- 
主从无法同步: - 检查防火墙是否开放 6379 端口:firewall-cmd --add-port=6379/tcp --permanent
- 确保主节点 redis.conf中bind 0.0.0.0
 
- 检查防火墙是否开放 6379 端口:
- 
Sentinel 不触发故障转移: - 确认至少有两个 Sentinel 能联通主节点
- 检查 sentinel.conf中的主节点 IP 和密码是否正确
 
- 
从节点无法提升为主节点: - 确保 redis.conf中未设置replica-read-only no(从节点默认只读)
 
- 确保 
扩展建议
- 监控 :使用 redis-cli info或 Prometheus + Redis Exporter
- 高可用:可增加更多 Sentinel 节点(建议至少 3 个)
- 安全:通过防火墙限制 Redis 和 Sentinel 端口的访问来源
此方案适合生产环境,如需更自动化部署,可结合 Ansible 或 Shell 脚本批量操作。