“工欲善其事,必先利其器”,要想在一分钟内搞定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哨兵模式内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!