docker+redis哨兵模式(一主二从三哨兵)- docker-compose

一、docker-compose 安装:

sudo apt-get update
 
#安装最新的docke-ce
sudo apt-get install  docker-ce
 
# 下载最新的docker-compose
curl -L https://github.com/docker/compose/releases/download/1.25.0-rc4/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
 
# 修改docker-compose 权限
chmod +x /usr/local/bin/docker-compose

# 查看docker-compose 版本

docker-compose -v

二、部署
1 获取 redis 镜像
安装命令:docker pull redis:5.0.14

# 查询docker远程仓库

docker search redis

# docker拉取远程镜像

docker pull redis

# 查看镜像

docker images

# 查看容器

docker ps -a 

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

wget https://download.redis.io/redis-stable/sentinel.conf

将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
发现从机变为主机,如下图:

 

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
THE END
分享
二维码
< <上一篇

)">
下一篇>>