CentOS环境搭建Redis哨兵模式集群

1.安装yum添加epel源

yum install epel-release
  1. 安装Redis
yum install redis
  1. 目录和配置文件管理
# 创建目录  
mkdir -p /etc/redis/{6380,6381,6382}  
mkdir -p /etc/redis-sentinel/{26380,26381,26382}  
  
# 复制配置文件,并修改文件名以区分不同实例  
cp /etc/redis.conf /etc/redis/6380/redis.conf  
cp /etc/redis.conf /etc/redis/6381/redis.conf  
cp /etc/redis.conf /etc/redis/6382/redis.conf  
  
# 注意:sentinel.conf文件通常不是直接通过cp创建的,而是需要手动编辑  
touch /etc/redis-sentinel/26380/sentinel.conf  
touch /etc/redis-sentinel/26381/sentinel.conf  
touch /etc/redis-sentinel/26382/sentinel.conf
  1. 数据节点配置(redis.conf)
    对于每个Redis实例的配置文件(redis.conf),需要修改以下关键项:
# ... 其他配置项 ...  
  
# 指定端口  
port 6380 # 根据实例修改  
  
# 绑定所有地址  
bind 0.0.0.0  
  
# PID文件路径  
pidfile /var/run/redis_6380.pid # 根据实例修改  
  
# 日志文件路径  
logfile /var/log/redis/redis_6380.log # 根据实例修改  
  
# 数据目录路径  
dir /var/lib/redis/6380 # 根据实例修改  
  
# 密码配置(可选)  
masterauth your_master_password # 如果设置了主节点密码  
requirepass your_redis_password # Redis实例密码  
  
# ... 其他配置项 ...

注意:在slaveof指令中,不要在配置文件中硬编码主节点的IP地址,因为哨兵会负责故障转移和更新从节点的配置。
5.哨兵配置(sentinel.conf)
对于每个哨兵的配置文件(sentinel.conf),需要修改以下关键项:

# ... 其他配置项 ...  
  
# 指定哨兵端口  
port 26380 # 根据哨兵实例修改  
  
# 日志文件路径  
logfile "/var/log/redis/sentinel_26380.log" # 根据哨兵实例修改  
  
# 哨兵监控的主节点配置  
sentinel monitor mymaster <master-ip> 6380 2 # 使用实际的主节点IP地址  
  
# 哨兵判断主节点宕机需要的毫秒数  
sentinel down-after-milliseconds mymaster 3000  
  
# ... 其他配置项 ...

注意:应该替换为实际的主节点IP地址,而不是127.0.0.0。
6.启动配置文件修改

# redis-6380.service
[Unit]
Description=Redis persistent key-value database
After=network.target

[Service]
ExecStart=/usr/bin/redis-server /etc/redis/6380/redis_6380.conf --supervised systemd
ExecStop=/usr/libexec/redis-shutdown
Type=notify
User=redis
Group=redis
RuntimeDirectory=redis
RuntimeDirectoryMode=0755

[Install]
WantedBy=multi-user.target
# redis-sentinel-26380.service  
[Unit]  
Description=Redis Sentinel  
After=network.target  
  
[Service]  
ExecStart=/usr/bin/redis-sentinel /etc/redis-sentinel/26380/sentinel_26380.conf --supervised systemd  
ExecStop=/usr/bin/redis-cli -p 26380 SHUTDOWN  
Type=notify  
User=redis  
Group=redis  
RuntimeDirectory=redis  
RuntimeDirectoryMode=0755  
Restart=on-failure  
  
[Install]  
WantedBy=multi-user.target

现在,您可以按照以下命令来更新systemd、使能服务为开机自启,并启动它们:

# 更新启动项  
systemctl daemon-reload  
  
# 设置开机自启(其他配置依次执行)  
systemctl enable redis-6380.service  
systemctl enable redis-6381.service  
systemctl enable redis-6382.service  
systemctl enable redis-sentinel-26380.service  
systemctl enable redis-sentinel-26381.service  
systemctl enable redis-sentinel-26382.service  
  
# 服务启动(先主后从)  
systemctl start redis-6380.service  
systemctl start redis-6381.service  
systemctl start redis-6382.service  
  
# 启动哨兵  
systemctl start redis-sentinel-26380.service  
systemctl start redis-sentinel-26381.service  
systemctl start redis-sentinel-26382.service  
  
# 查看进程  
ps -ef | grep redis  
# 或者查看systemd服务的状态  
systemctl status redis-6380.service  
systemctl status redis-sentinel-26380.service  
# 以此类推,查看其他服务和哨兵的状态

在这里插入图片描述
遇到问题:
(1)在/tmp文件夹下创建/tmp/redis-sentinel/26380目录
在这里插入图片描述(2)Could not create server TCP listening socket 0.0.0.0:6380: bind: Permission denied

# 停止firewalld服务
systemctl stop firewalld
# 禁用firewalld服务,确保其在系统重新启动后不会自动启动
systemctl disable firewalld

码客笔记,分享更有用的技术知识,助你成为更优秀的开发者!快来关注我们吧!

  • 8
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

码客笔记

你的鼓励将是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值