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

作者:神州永泰 时间:2021-02-23 13:51:53 

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

2 建目录

命令1:

mkdir /usr/local/etc/redis

命令2:

mkdir /usr/local/etc/redis/sentinel

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

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哨兵模式

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

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

命令:

docker inspect redis-master

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

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哨兵模式


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

三、验证方法

1 验证是否安装好

*检测容器命令:

docker ps

看是否有以下6个容器。

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

*登录主机命令:

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

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

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

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

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

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

*登录哨兵命令:

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

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

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

*查看哨兵sentinel日志:

命令:

docker logs -f redis-sentinel1

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

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

2 1验证主从机切换

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

命令:

docker stop redis-master

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

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

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

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

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

来源:https://blog.csdn.net/helloworldchina/article/details/127355618

标签:docker,redis,哨兵
0
投稿

猜你喜欢

  • 把域名转移到Godaddy图文教程

    2010-04-07 12:30:00
  • GoDaddy主机下载备份文件到本地磁盘的方法

    2010-04-12 13:14:00
  • 苹果将积极为自己辩护 反击诺基亚侵权诉讼

    2009-10-30 07:54:00
  • 糟糕的网站用户体验最高境界

    2007-11-02 00:03:00
  • 我的西联汇款取款经历

    2009-04-03 12:54:00
  • 关于robots.txt无法禁止收录的小看法

    2011-10-14 20:34:22
  • 赵宜君:网站排名与搜索引擎快照的关系

    2008-12-30 13:39:00
  • Z-Blog防治垃圾留言的策略

    2008-10-30 13:16:00
  • 深入剖析IIS 6.0图文教程

    2010-04-04 18:18:00
  • 巨人网络网游新作《绿色征途》率先兼容Win 7

    2009-10-23 07:54:00
  • 王通谈针对搜索引擎优化的八大要素

    2007-08-16 12:44:00
  • centos7.x 部署主、从DNS服务器问题

    2023-07-01 12:44:08
  • linux操作系统下配置ssh/sftp和权限设置方法

    2023-09-01 08:40:19
  • linux常用命令之VMware10中安装CentOS 6.4图文教程

    2023-01-22 05:39:23
  • 袁兴伟携数千万腾讯网友助力绿色世博

    2009-10-14 09:58:00
  • 全面解析企业服务器I/O优化

    2009-12-18 10:42:00
  • 详谈robots.txt的好处与坏处

    2008-07-22 12:52:00
  • 配置emule的web服务器功能详解

    2009-01-06 17:00:00
  • 基于WordPress网站的优化

    2011-05-12 14:26:00
  • 不要小看长尾词的流量

    2008-06-13 12:46:00
  • asp之家 网站运营 m.aspxhome.com