加入收藏 | 设为首页 | 会员中心 | 我要投稿 云计算网_汕头站长网 (https://www.0754zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 服务器 > 搭建环境 > Linux > 正文

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

发布时间:2022-10-12 12:57:05 所属栏目:Linux 来源:
导读:  本文主要讲述在 Linux 系统中配置和部署 Redis 主从集群和哨兵,实现高可用和自动故障迁移。

  准备工作

  参考 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
 

(编辑:云计算网_汕头站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!