在Linux部署Redis主从和哨兵集群实现高可用

发布时间 2023-04-05 16:59:22作者: 我有八千部下

前言

本文主要讲述在 Linux 系统中配置和部署 Redis 主从集群和哨兵,实现高可用和自动故障迁移。

准备工作

参考 Redis 单机部署 安装 3 个 Redis 服务作一主二从,本文准备了 6380(主)、6381(从) 和 6382(从)。

参考 Redis 单机部署 安装 3 个 Redis 服务作哨兵集群,本文准备了 26380、26381 和 26382。

开始前最好先停止这几个服务。

启动主从节点

启动主节点

service redis_6380 start

启动从节点三种方式

下面的步骤每个从节点都需要执行,修改对应从节点端口号即可。

  • redis-cli 指令,从节点重启后跟随会失效
# 启动从节点
service redis_6381 start

# redis-cli 连接从节点
redis-cli -p 6381

# 如果主节点有密码需要执行这一条指令
config set masterauth <password>

# 跟随 6380 主节点
REPLICAOF 127.0.0.1 6380
  • 启动时配置,从节点重启后跟随会失效
redis-server /etc/redis/6381.conf --replicaof 127.0.0.1 6380
  • 通过配置文件(推荐)
echo "编辑配置文件"
vim /etc/redis/6381.conf
# 主节点IP和端口号
replicaof 127.0.0.1 6380

# 主节点密码,如果有的话
masterauth <master-password>
echo "启动从节点"
service redis_6381 start

测试

通过redis-cli连接主节点6380写入数据

# 连接主节点
redis-cli -p 6380

# 写入数据
set key1 key1

然后连接任一从节点可以看到相同数据

# 连接从节点
redis-cli -p 6381

# 写入数据
keys *

通过从节点可以查询,但它是只读的,不能写数据,写入会返回错误。

image-20210926162749342

部署哨兵

安装服务时,脚本帮我们创建了相关目录、文件、作为服务启动的脚本以及配置了开机启动。但它是当成 Redis 服务创建的,而我们要的是哨兵,所以需要替换成哨兵的配置文件,并对相关路径进行修改,并且需要将服启动脚本启动命令加上 --sentinel 表示启动的是哨兵服务。

每个哨兵服务配置步骤都一样,根据端口号改对应地方。

修改配置

替换、编辑配置文件

# 拷贝源码目录下哨兵配置文件,替换掉安装服务自动创建的配置文件。提示时输入 y 回车
cp ~/soft/redis/redis-6.2.5/sentinel.conf /etc/redis/26380.conf

# 编辑配置文件
vim /etc/redis/26380.conf
# 端口号
port 26380
# pid 文件路径
pidfile /var/run/redis_26380.pid
# 日志文件路径
logfile /var/log/redis_26380.log
# 数据文件路径
dir /var/lib/redis/26380
# sentinel monitor <主节点别名,每个集群主别名唯一> <主节点IP> <主节点端口号> <n个哨兵认为主节点主观下线,才会将主节点标记为客观下线>
sentinel monitor mymaster 127.0.0.1 6380 2
# 后台启动
daemonize yes

一套哨兵集群可以监控多套主从集群sentinel monitor指定各个集群主节点就行了,主节点别名必须唯一。如:

sentinel monitor mymaster 127.0.0.1 6380 2
sentinel monitor mymaster2 127.0.0.1 6383 2

修改服务脚本

  • 编辑对应的脚本,在追加启动参数 --sentinel 如下图所示
vim /etc/init.d/redis_26380

在这里插入图片描述

启动哨兵

service redis_26380 start

测试

停掉主节点。

service redis_6380 stop

通过redis-cli连接任一哨兵查看集群状态,可以看到主节点切换到了6382,这时可以通过连接6382来写入数据了。

# 连接哨兵
redis-cli -p 26380

# 查看主节点信息
sentinel master mymaster

image-20210926162518670

再看看从节点信息,可以看到6380变成了从节点,并且状态为s_down,代表下线

sentinel slaves mymaster

image-20210926163121065

image-20210926163148079

旧主节点重启后状态就正常了,不过它已经是从节点了,不会变回去。

service redis_6380 start

image-20210926163408120

其他问题

服务启动失败

服务停止后,再次启动失败显示下面信息,可以删掉提示的 pid 文件再启动

/var/run/redis_6380.pid exists, process is already running or crashed

参考链接

Redis 中文网文档