在Linux部署Redis主从和哨兵集群实现高可用
前言
本文主要讲述在 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 *
通过从节点可以查询,但它是只读的,不能写数据,写入会返回错误。
部署哨兵
安装服务时,脚本帮我们创建了相关目录、文件、作为服务启动的脚本以及配置了开机启动。但它是当成 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
再看看从节点信息,可以看到6380变成了从节点,并且状态为s_down,代表下线
sentinel slaves mymaster
旧主节点重启后状态就正常了,不过它已经是从节点了,不会变回去。
service redis_6380 start
其他问题
服务启动失败
服务停止后,再次启动失败显示下面信息,可以删掉提示的 pid 文件再启动
/var/run/redis_6380.pid exists, process is already running or crashed