教你一分钟搞定docker+redis哨兵模式

 更新时间:2023年03月31日 15:54:34   作者:神州永泰  
这篇文章主要介绍了教你一分钟搞定docker+redis哨兵模式,本文主要讲解一主二从三哨兵,特将其部署到一台机器上,并通过端口区分,需要的朋友可以参考下

“工欲善其事,必先利其器”,要想在一分钟内搞定docker+redis哨兵模式(一主二从三哨兵),按下述方法,则快捷,迅速,省时省力:

注:本文主要讲解一主二从三哨兵,特将其部署到一台机器上,并通过端口区分(生产环境要部署到三台及以上机器上)。

一 前期准备工作

要求具备下面环境或相应适配版本环境:

※Centos 7.9版
※GNU Make 3.82版
※gcc 4.8.5版
※Docker 20.10.18版
※sentinel.conf文件
下载方法:
wget https://download.redis.io/redis-stable/sentinel.conf

※docker-compose 1.29.2版
技术更新较快,用docker-compose比较快捷。
安装方法:

命令1:

curl -L https://get.daocloud.io/docker/compose/releases/download/1.29.2/docker-compose-uname -s-uname -m > /usr/local/bin/docker-compose

命令2:

chmod +x /usr/local/bin/docker-compose

在这里插入图片描述

二、部署(一分钟)

1、获取 redis 镜像

安装命令:

docker pull redis:5.0.14

在这里插入图片描述

2 建目录

命令1:

mkdir /usr/local/etc/redis

命令2:

mkdir /usr/local/etc/redis/sentinel

在这里插入图片描述

3 在 /usr/local/etc/redis 目录下,新建 docker-compose.yml文件

version: '3'
services:
  master:
    image: redis
    container_name: redis-master
    command: redis-server
    ports:
      - 6379:6379
  slave1:
    image: redis
    container_name: redis-slave1
    ports:
      - 6380:6380
    command:  redis-server --slaveof redis-master 6379
  slave2:
    image: redis
    container_name: redis-slave2
    ports:
      - 6381:6381
    command: redis-server --slaveof redis-master 6379

4 启动 redis 集群

在./redis目录运行命令:

docker-compose up -d

在这里插入图片描述

5查看 redis-master 节点的 docker-ip 和 network name,

见下图,并记住,待配置sentinel的docker-compose文件时用。

命令:

docker inspect redis-master

在这里插入图片描述

6.在 /usr/local/etc/redis/sentinel 目录下,新建 docker-compose.yml文件

version: '3'
services:
  sentinel1:
    image: redis
    container_name: redis-sentinel1
    ports:
      - 26379:26379
    command: redis-sentinel /usr/local/etc/redis/sentinel/sentinel1.conf
    volumes:
      - ./sentinel1.conf:/usr/local/etc/redis/sentinel/sentinel1.conf
  sentinel2:
    image: redis
    container_name: redis-sentinel2
    ports:
    - 26380:26380
    command: redis-sentinel /usr/local/etc/redis/sentinel/sentinel2.conf
    volumes:
      - ./sentinel2.conf:/usr/local/etc/redis/sentinel/sentinel2.conf
  sentinel3:
    image: redis
    container_name: redis-sentinel3
    ports:
      - 26381:26381
    command: redis-sentinel /usr/local/etc/redis/sentinel/sentinel3.conf
    volumes:
      - ./sentinel3.conf:/usr/local/etc/redis/sentinel/sentinel3.conf
networks:
  default:
    external:
      name: redis_default

7 将sentinel.conf文件拷贝至/usr/local/etc/redis/sentinel

并复制三份,名称分别为sentinel1.conf 、 sentinel2.conf 、 sentinel3.conf,分别修改三个文件:

修改的内容如下:

修改 sentinel1.conf
文件修改内容如下:

protected-mode no
daemonize yes
port 26379 #sentinel 端口
sentinel monitor mymaster 172.18.0.3 6379 2 #注:172.18.0.3为redis-master的dockerIP

然后修改sentinel2.conf信息如下:

protected-mode no
daemonize yes
port 26380 # sentinel 端口,因为我们在一台虚拟机上,所以端口要不一样
sentinel monitor mymaster 172.18.0.3 6379 2 #注:172.18.0.3为redis-master的dockerIP

然后修改sentinel3.conf信息如下:

protected-mode no
daemonize yes
port 26381 # sentinel 端口,因为我们在一台虚拟机上,所以端口要不一样
dir “/var/llib/redis”
sentinel monitor mymaster 172.18.0.3 6379 2 #注:172.18.0.3为redis-master的dockerIP

8 在./sentinel目录启动 sentinel 集群

命令:

docker-compose up -d

在这里插入图片描述


经此8步,完成docker下的redis一主二从三哨兵模式。

三、验证方法

1 验证是否安装好

*检测容器命令:

docker ps

看是否有以下6个容器。

在这里插入图片描述

*登录主机命令:

docker exec -it redis-master /bin/bash
redis-cli
info Replication

出现下面画面,证明redis主机安装成功。

在这里插入图片描述

*登录从机redis-slave1及redis-slave2命令:

在这里插入图片描述

在这里插入图片描述

*登录哨兵命令:

docker exec -it redis-sentinel1 /bin/bash
redis-cli -p 26379
info sentinel

如下图,则哨兵安装成功。

在这里插入图片描述

*查看哨兵sentinel日志:

命令:

docker logs -f redis-sentinel1

如下图所示,也证明哨兵安装成功

在这里插入图片描述

2 1验证主从机切换

*停掉主机redis-master服务,可以直接将容器关掉。

命令:

docker stop redis-master

在这里插入图片描述

*登录从机1(slave1)
命令:

docker exec -it redis-slave1 /bin/bash
redis-cli
info Replication

发现从机变为主机,如下图:

在这里插入图片描述

到此这篇关于教你一分钟搞定docker+redis哨兵模式的文章就介绍到这了,更多相关docker+redis哨兵模式内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • docker-compose网络设置之networks的使用

    docker-compose网络设置之networks的使用

    本文详细解释了在使用 Docker Compose时如何配置网络,包括创建、使用和问题解决等方面,介绍了如何通过docker-compose.yml文件快速编排和部署应用服务,同时解决网络隔离问题,感兴趣的可以了解一下
    2024-10-10
  • 通过Docker部署Redis 6.x集群的方法

    通过Docker部署Redis 6.x集群的方法

    这篇文章主要介绍了通过Docker部署Redis 6.x集群的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03
  • Docker 部署 pSQL 服务器的详细教程

    Docker 部署 pSQL 服务器的详细教程

    本文详细介绍了如何使用Edu邮箱申请Azure订阅并开通免费VPS,以及在Ubuntu VPS上通过Docker部署pSQL服务器的方法,感兴趣的朋友跟随小编一起看看吧
    2025-02-02
  • Docker容器上用DockerFile部署多个tomcat服务的步骤

    Docker容器上用DockerFile部署多个tomcat服务的步骤

    这篇文章主要介绍了Docker容器上用DockerFile部署多个tomcat服务的步骤,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-11-11
  • Redis快速部署为Docker容器的实现方法

    Redis快速部署为Docker容器的实现方法

    本文主要介绍了Redis快速部署为Docker容器的实现方法,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-12-12
  • 一篇文章弄懂Docker镜像的制作、上传、拉取和部署

    一篇文章弄懂Docker镜像的制作、上传、拉取和部署

    Docker包含三个基本概念,分别是镜像(Image)、容器(Container)和仓库(Repository),镜像是 Docker 运行容器的前提,这篇文章主要给大家介绍了如何通过一篇文章弄懂Docker镜像的制作、上传、拉取和部署的相关资料,需要的朋友可以参考下
    2021-08-08
  • 在Docker容器中部署MSSQL

    在Docker容器中部署MSSQL

    这篇文章介绍了在Docker容器中部署MSSQL的方法,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-04-04
  • 如何使用Docker部署Xxl-Job分布式任务调度中心

    如何使用Docker部署Xxl-Job分布式任务调度中心

    XXL-Job是一个开源的分布式任务调度中心,它提供了一个可视化的任务管理界面,可以方便地创建、编辑和监控任务,本文详细的讲解了如何使用Docker部署xxl-job分布式任务调度服务,感兴趣的朋友跟随小编一起看看吧
    2024-03-03
  • 已有docker镜像构建过程分析(使用示例)

    已有docker镜像构建过程分析(使用示例)

    docker history命令用于查看指定镜像的历史层信息,它显示了镜像创建过程中的每一层,包括创建时间、创建者、大小和注释等信息,本文介绍已有docker镜像构建过程分析,感兴趣的朋友一起看看吧
    2024-12-12
  • Docker遇到Intellij IDEA,Java开发提升了十倍生产力

    Docker遇到Intellij IDEA,Java开发提升了十倍生产力

    这篇文章主要介绍了Docker遇到Intellij IDEA,Java开发提升了十倍生产力,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-10-10

最新评论