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

 更新时间:2023年11月04日 10:07:16   作者:葒脃坧頭  
这篇文章主要介绍了基于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

主库状态:

从上图看出:主库停掉,从库自动切换为主库;主库恢复,主库变为原从库的从。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 在docker-compose.yml文件中配置容器的环境变量方式

    在docker-compose.yml文件中配置容器的环境变量方式

    本文介绍了在docker-compose.yml文件中设置和使用环境变量的方法,包括直接设置环境变量、从文件读取环境变量以及使用多个环境文件进行不同部署环境的配置
    2024-11-11
  • 聊聊Docker中容器的创建与启停问题

    聊聊Docker中容器的创建与启停问题

    一个进程可以视为一个被执行的应用程序,同样,一个Docker容器可以视为一个运行中的Docker镜像,这篇文章主要介绍了Docker中容器的创建与启停,需要的朋友可以参考下
    2022-06-06
  • 如何将Docker的构建时间减少40%(推荐)

    如何将Docker的构建时间减少40%(推荐)

    这篇文章主要介绍了如何将Docker的构建时间减少40%,本文描述了我们在优化CI管道后获得的一些新见解,需要的朋友可以参考下
    2023-11-11
  • Docker容器的概念及Docker容器是干什么的

    Docker容器的概念及Docker容器是干什么的

    Docker容器是一种轻量级、可移植的虚拟化技术,用于打包、运输和运行应用程序及其所有依赖项,Docker容器使得开发人员能够更轻松地构建、交付和运行应用程序,同时提高了资源利用率和部署的一致性,感兴趣的朋友跟随小编一起看看吧
    2024-02-02
  • Linux环境docker部署Firefox结合内网穿透远程使用浏览器测试的示例详解

    Linux环境docker部署Firefox结合内网穿透远程使用浏览器测试的示例详解

    在Docker中打开Firefox意味着我们将在一个Docker容器中运行Firefox浏览器,这对于一些特殊的测试场景非常有用,例如需要在不同版本的浏览器中进行测试,下面是一个简单的示例,演示如何在Docker中打开Firefox,感兴趣的朋友跟随小编一起看看吧
    2024-08-08
  • Docker在WSL环境下启动失败的问题解决办法

    Docker在WSL环境下启动失败的问题解决办法

    在Windows系统上,有时候我们可能会遇到Docker启动失败的问题,特别是在使用WSL(Windows Subsystem for Linux)作为Docker运行环境时,这篇文章主要介绍了Docker在WSL环境下启动失败问题的解决办法,需要的朋友可以参考下
    2025-07-07
  • Docker安装部署rocketmq-console工具教程

    Docker安装部署rocketmq-console工具教程

    这篇文章主要介绍了Docker安装部署rocketmq-console工具教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-04-04
  • Docker安装Oracle_11g的方法

    Docker安装Oracle_11g的方法

    这篇文章主要介绍了Docker安装Oracle_11g的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-04-04
  • Navicat 连接服务器端中的docker数据库的方法

    Navicat 连接服务器端中的docker数据库的方法

    这篇文章主要介绍了Navicat 连接服务器端中的docker数据库,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-03-03
  • 详解Docker挂载本地目录及实现文件共享的方法

    详解Docker挂载本地目录及实现文件共享的方法

    本篇文章主要介绍了详解Docker挂载本地目录及实现文件共享的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-12-12

最新评论