在Linux部署Redis主从和哨兵集群实现高可用
发布时间:2022-10-12 12:57:05 所属栏目:Linux 来源:
导读: 本文主要讲述在 Linux 系统中配置和部署 Redis 主从集群和哨兵,实现高可用和自动故障迁移。
准备工作
参考 Redis 单机部署 安装 3 个 Redis 服务作一主二从,本文准备了 6380(主)、6381(从) 和
准备工作
参考 Redis 单机部署 安装 3 个 Redis 服务作一主二从,本文准备了 6380(主)、6381(从) 和
|
本文主要讲述在 Linux 系统中配置和部署 Redis 主从集群和哨兵,实现高可用和自动故障迁移。 准备工作 参考 Redis 单机部署 安装 3 个 Redis 服务作一主二从,本文准备了 6380(主)、6381(从) 和 6382(从)。 参考 Redis 单机部署 安装 3 个 Redis 服务作哨兵集群,本文准备了 26380、26381 和 26382。 开始前最好先停止这几个服务。 启动主从节点启动主节点 service redis_6380 start 启动从节点三种方式 下面的步骤每个从节点都需要执行,修改对应从节点端口号即可。 # 启动从节点 service redis_6381 start # redis-cli 连接从节点 redis-cli -p 6381 # 如果主节点有密码需要执行这一条指令 config set masterauth # 跟随 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 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> <主节点端口号> 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 修改服务脚本 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 旧主节点重启后状态就正常了集群linux,不过它已经是从节点了,不会变回去。 service redis_6380 start 其他问题服务启动失败 服务停止后,再次启动失败显示下面信息,可以删掉提示的 pid 文件再启动 /var/run/redis_6380.pid exists, process is already running or crashed (编辑:云计算网_汕头站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
站长推荐


浙公网安备 33038102330478号