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

本站所有内容来自互联网收集,仅供学习和交流,请勿用于商业用途。如有侵权、不妥之处,请第一时间联系我们删除!Q群:迪思分享

免费资源网 – https://freexyz.cn/
目录一 前期准备工作二、部署(一分钟)1、获取 redis 镜像2 建目录3 在 /usr/local/etc/redis 目录下,新建 docker-compose.yml文件4 启动 redis 集群5查看 redis-master 节点的 docker-ip 和 network name,6.在 /usr/local/etc/redis/sentinel 目录下,新建 docker-compose.yml文件7 将sentinel.conf文件拷贝至/usr/local/etc/redis/sentinel8 在./sentinel目录启动 sentinel 集群三、验证方法1 验证是否安装好2 1验证主从机切换

“工欲善其事,必先利其器”,要想在一分钟内搞定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

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

二、部署(一分钟)

1、获取 redis 镜像

安装命令:

docker pull redis:5.0.14

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

2 建目录

命令1:

mkdir /usr/local/etc/redis

命令2:

mkdir /usr/local/etc/redis/sentinel

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

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

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

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

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

命令:

docker inspect redis-master

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

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

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

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

三、验证方法

1 验证是否安装好

*检测容器命令:

docker ps

看是否有以下6个容器。

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

*登录主机命令:

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

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

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

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

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

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

*登录哨兵命令:

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

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

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

*查看哨兵sentinel日志:

命令:

docker logs -f redis-sentinel1

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

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

2 1验证主从机切换

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

命令:

docker stop redis-master

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

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

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

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

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

免费资源网 – https://freexyz.cn/


© 版权声明
THE END
★喜欢这篇文章吗?喜欢的话,麻烦动动手指支持一下!★
点赞6 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容