基于docker的redis主从及哨兵配置

`简介`
5.0.0之前,Redis主从一直使用 SLAVEOF 作为复制命令,但是从 5.0.0 版本开始,
Redis 正式将 SLAVEOF 命令改名成了 REPLICAOF 命令并逐渐废弃原来的 SLAVEOF 命令。
以下我用docker安装redis方式比较复杂(个人习惯,如有需要可从我的docker仓库下载),
用官网的镜像安装即可,配置直接从第四步开始。
通过官方镜像安装:
docker pull redis
docker run -itd --name redis-master redis bash
docker run -itd --name redis-slave  redis bash

安装完配置文件需要下载,完成直接从第四步开始即可。
1、下载镜像
在这里插入图片描述
2、启动容器master和slave:

dvr start redis

启动如下:
在这里插入图片描述
3、进入容器,进行redis安装

docker exec -it redis_master_1 bash
docker exec -it redis_slave_1 bash
apt update
apt upgrade
apt install redis -y

4、配置主从
master修改:

vim /etc/redis/redis.conf
56 # bind 127.0.0.1 ::1   #注释此行,否则只能本机访问
88 protected-mode no      #关闭保护模式
136 daemonize yes         #服务后台启动
500 requirepass foobared  #开启密码认证(可选,若此无设置,从库亦无须认证)

slave修改:

vim /etc/redis/redis.conf
56 # bind 127.0.0.1 ::1        #注释此行,否则只能本机访问
88 protected-mode no           #关闭保护模式
136 daemonize yes              #服务后台启动
281 slaveof 172.18.62.27 6379  #主从配置
288 masterauth foobared        #主从配置密码认证(若主无密码,无需置)
500 requirepass foobared       #开启密码认证(可选)

5、启动主库和从库的服务

/etc/init.d/redis-server start

主库启动
从库启动
6、主从验证
登录:

redis-cli -a foobared

查看状态:

INFO replication

master:
master
slave:
在这里插入图片描述
数据验证:
在这里插入图片描述
在这里插入图片描述
到此,redis主从配置完成
7、redis哨兵配置
此处以三哨兵为例,哨兵个数为奇数个,不然选主将无法进行,三个哨兵我放在salve上,也可单独准备三个容器运行哨兵服务
哨兵配置如下:
哨兵1:

vim /etc/redis/sentinel1.conf
protected-mode no                                #关闭保护模式
port 26379                                       #运行端口
daemonize yes
pidfile /var/run/redis-sentinel1.pid
logfile "/var/log/redis/sentinel1_log"
sentinel monitor mymaster 172.18.62.27 6379 2    #配置master地址,及需要哨兵票数
sentinel auth-pass mymaster foobared             #密码认证(若主从都为设密码,不用此配置)
sentinel down-after-milliseconds mymaster 30000
sentinel failover-timeout mymaster 180000
sentinel parallel-syncs mymaster 1

哨兵2

vim /etc/redis/sentinel2.conf
protected-mode no                                #关闭保护模式
port 26378                                       #运行端口
daemonize yes
pidfile /var/run/redis-sentinel2.pid
logfile "/var/log/redis/sentinel2_log"
sentinel monitor mymaster 172.18.62.27 6379 2    #配置master地址,及需要哨兵票数
sentinel auth-pass mymaster foobared             #密码认证(若主从都为设密码,不用此配置)
sentinel down-after-milliseconds mymaster 30000
sentinel failover-timeout mymaster 180000
sentinel parallel-syncs mymaster 

哨兵3

vim /etc/redis/sentinel3.conf
protected-mode no                                #关闭保护模式
port 26377                                       #运行端口
daemonize yes
pidfile /var/run/redis-sentinel3.pid
logfile "/var/log/redis/sentinel3_log"
sentinel monitor mymaster 172.18.62.27 6379 2    #配置master地址,及需要哨兵票数
sentinel auth-pass mymaster foobared             #密码认证(若主从都为设密码,不用此配置)
sentinel down-after-milliseconds mymaster 30000
sentinel failover-timeout mymaster 180000
sentinel parallel-syncs mymaster 

8、启动哨兵:

redis-server sentinel1.conf --sentinel
redis-server sentinel2.conf --sentinel
redis-server sentinel3.conf --sentinel

如下:
在这里插入图片描述
9、进行测试
我们停掉主库

/etc/init.d/redis-server stop

在这里插入图片描述
查看从库状态:
从库切换
启动主库:

/etc/init.d/redis-server start

主库状态:
在这里插入图片描述
从上图看出:主库停掉,从库自动切换为主库;主库恢复,主库变为原从库的从。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值