基于docker的redis主从及哨兵配置方式
作者:葒脃坧頭
这篇文章主要介绍了基于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:
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
主库状态:
从上图看出:主库停掉,从库自动切换为主库;主库恢复,主库变为原从库的从。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。