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

前言

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

准备工作

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

参考 Redis 单机部署[2] 安装 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 *

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

在Linux部署Redis主从和哨兵集群实现高可用
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

    在Linux部署Redis主从和哨兵集群实现高可用
    在这里插入图片描述


启动哨兵

service redis_26380 start

测试

停掉主节点。

service redis_6380 stop

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

连接哨兵
redis-cli -p 26380

查看主节点信息
sentinel master mymaster
在Linux部署Redis主从和哨兵集群实现高可用
image-20210926162518670

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

sentinel slaves mymaster
在Linux部署Redis主从和哨兵集群实现高可用
image-20210926163121065
在Linux部署Redis主从和哨兵集群实现高可用
image-20210926163148079

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

service redis_6380 start
在Linux部署Redis主从和哨兵集群实现高可用
image-20210926163408120

其他问题

服务启动失败

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

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

参考链接

Redis 中文网文档[3]

引用链接

[1] Redis 单机部署: https://blog.csdn.net/qq_27022339/article/details/119452528
[2] Redis 单机部署: https://blog.csdn.net/qq_27022339/article/details/119452528
[3] Redis 中文网文档: http://redis.cn/documentation.html


原文始发于微信公众号(我有八千部下):在Linux部署Redis主从和哨兵集群实现高可用

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/102642.html

(0)
小半的头像小半

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!