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

这篇具有很好参考价值的文章主要介绍了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

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

 文章来源地址https://www.toymoban.com/news/detail-457566.html

5 查看 redis-master 节点的 docker-ip 和 network name,见下图,并记住,待配置sentinel的docker-compose文件时用。

命令:docker inspect redis-master

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

 

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

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

 

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

三、验证方法
1 验证是否安装好
*检测容器命令:docker ps
看是否有以下6个容器。

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

 


*登录主机命令:
docker exec -it redis-master /bin/bash
redis-cli
info Replication
出现下面画面,证明redis主机安装成功。

 

 

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

 

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

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

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

 

*登录哨兵命令:
docker exec -it redis-sentinel1 /bin/bash
redis-cli -p 26379
info sentinel
如下图,则哨兵安装成功。

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


*查看哨兵sentinel日志:
命令:docker logs -f redis-sentinel1
如下图所示,也证明哨兵安装成功

 

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

 

2 1验证主从机切换
*停掉主机redis-master服务,可以直接将容器关掉。
命令:docker stop redis-master

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

 

*登录从机1(slave1)
命令:
docker exec -it redis-slave1 /bin/bash
redis-cli
info Replication
发现从机变为主机,如下图:

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

 

到了这里,关于docker+redis哨兵模式(一主二从三哨兵)- docker-compose的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Redis——哨兵模式(docker部署redis哨兵)+缓存穿透和雪崩

    自动选取主机的模式。 主从切换技术的方法是:当主服务器宕机后,需要手动把一台从服务器切换为主服务器,这就需要人工干预,费事费力,还会造成段时间内服务不可用。这不是一种推荐的方式,更多时候,我们优先考虑哨兵模式。Redis从2.8开始正式提供了Sentinel(哨兵)架

    2024年02月12日
    浏览(26)
  • 利用docker搭建redis哨兵模式

    一主二从三哨兵,如果Master 节点断开了,这个时候就会从从机中随机选择一个服务器! (这里面有一个投票算法!)如果主机此时回来了,只能归并到新的主机下,当做从机,这就是哨兵模式的规则! 主机:设置key 从机:读取key,有数据代表主从实现成功 注意:不同版本的

    2024年02月06日
    浏览(33)
  • 使用docker快速搭建redis哨兵模式

    本文主要参考: https://www.cnblogs.com/coderaniu/p/15352323.html https://developer.aliyun.com/article/892805 但是这两篇博客均缺失部分关键性细节,所以重新撰文。读者可以结合本文和上述文章一起阅读。 此处略 创建 docker-compose.yml 文件,内容如下: 执行命令 docker-compose up -d 创建三个redis容器

    2024年02月09日
    浏览(28)
  • 【Redis】Redis哨兵模式

    Redis主从模式当主服务器宕机后,需要手动把一台从服务器切换为主服务器,需要人工干预费事费力,为了解决这个问题出现了哨兵模式。 哨兵模式是是一个管理多个 Redis 实例的工具,它可以实现对 Redis 的监控、通知、自动故障转移,是Redis实现高可用的方案。哨兵模式能够

    2024年02月12日
    浏览(27)
  • 使用Docker搭建一个“一主两从”的 Redis 集群(超详细步骤)

    1、Redis 单机版安装 1.1 拉取 Redis 首先从 docker hub 拉取 Redis 镜像,这里拉取 7.0 版。 1.2 创建数据卷目录 首先要在宿主机/root 目录中创建一个目录 redis,将来用于存放外挂文件 redis.conf。 使用rz命令上传一份redis.conf: 1.3 修改 redis.conf 修改配置文件: 1.解除 IP 绑定 将 bind 行注释

    2024年02月21日
    浏览(36)
  • Redis之哨兵模式解读

    目录 基本介绍 单哨兵模式 多哨兵模式 哨兵的本质 配置哨兵模式 故障恢复原理 哨兵监控工作流程 哨兵模式缺点  基本介绍 当主服务器宕机后, 需要手动把一台从服务器切换为主服务器,这就需要人工干预,费事费力,还会造成一段时间内服务不可用。 这不是一种推荐的方式

    2024年02月09日
    浏览(33)
  • Redis Sentinel 哨兵模式

    Sentinel 哨兵模式  Redis Sentinel 官网  Redis 的 Sentinel 文档 -- Redis中国用户组(CRUG)  Sentinel Redis 命令参考(红色)  Sentinel 通过监控的方式获取主机的工作状态是否正常,当主机发生故障时, Sentinel 会自动进行 Failover(即故障转移),并将其监控的从机提升主服务器(master)

    2024年02月06日
    浏览(39)
  • Redis_哨兵模式

    当主库宕机,在从库中选择一个,切换为主库。 问题: 主库是否真正宕机? 哪一个从库可以作为主库使用? 如何实现将新的主库的信息通过给从库和客户端? 哨兵主要任务: 监控 选择主库 通知 会有主观下线和客观下线,就是奇数个哨兵,少数服从多数,多数以为主服务器宕

    2024年02月13日
    浏览(36)
  • Redis之哨兵模式

    从主从复制到哨兵模式。 主从复制,是指将一台 Redis 服务器的数据,复制到其他的 Redis 服务器。 前者称为主节点(master / leader),后者称为从节点(slave/follower)。 数据的复制是单向的,只能由主节点到从节点。 Master 以写为主,Slave 以读为主。 一个主节点可以有多个从节

    2024年02月06日
    浏览(25)
  • Redis教程-哨兵模式

    当涉及到 Redis 哨兵模式的教程时,下面是一个简要的教程,涵盖了哨兵模式的作用以及如何进行配置。 Redis 哨兵模式是一种用于高可用性的 Redis 部署方案。它通过监控和管理 Redis 主服务器(Master)和从服务器(Slave)的状态,实现自动故障转移和故障恢复。 哨兵模式的主要

    2024年02月10日
    浏览(26)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包