使用Docker Compose搭建Redis哨兵架构

这篇具有很好参考价值的文章主要介绍了使用Docker Compose搭建Redis哨兵架构。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

搭建Redis哨兵(sentinel)

之前我们通过深入理解REDIS哨兵原理了解了Redis哨兵(sentinel)的原理,今天我们手动部署一个哨兵架构。要在Docker中搭建Redis哨兵(sentinel)架构,需要Redis的主从实例以及哨兵实例。之前我们已经使用Docker Compose搭建Redis主从复制过了,下面我们通过Docker Compose创建一个Redis哨兵架构。

使用Docker Compose搭建Redis哨兵架构,java,redis,docker

3. 创建docker-compose.yml文件,内容如下

  version: '3'
  services:
    redis-master:
      image: redis:latest
      container_name: redis-master
      ports:
        - "6379:6379"
      command: redis-server

    redis-slave1:
      image: redis:latest
      container_name: redis-slave1
      ports:
        - "6380:6379"
      command: redis-server --slaveof redis-master 6379

    redis-slave2:
      image: redis:latest
      container_name: redis-slave2
      ports:
        - "6381:6379"
      command: redis-server --slaveof redis-master 6379

    redis-sentinel1:
      image: redis:latest
      container_name: redis-sentinel1
      ports:
        - "26379:26379"
      command: redis-sentinel /etc/redis-config/sentinel.conf
      volumes:
        - "./sentinel1/conf/sentinel.conf:/etc/redis-config/sentinel.conf"
      depends_on:
        - redis-master
        - redis-slave1
        - redis-slave2

    redis-sentinel2:
      image: redis:latest
      container_name: redis-sentinel2
      ports:
        - "26380:26379"
      command: redis-sentinel /etc/redis-config/sentinel.conf
      volumes:
        - "./sentinel2/conf/sentinel.conf:/etc/redis-config/sentinel.conf"
      depends_on:
        - redis-master
        - redis-slave1
        - redis-slave2

    redis-sentinel3:
      image: redis:latest
      container_name: redis-sentinel3
      ports:
        - "26381:26379"
      command: redis-sentinel /etc/redis-config/sentinel.conf
      volumes:
        - "./sentinel3/conf/sentinel.conf:/etc/redis-config/sentinel.conf"
      depends_on:
        - redis-master
        - redis-slave1
        - redis-slave2

    在这个示例中,我们有一个名为redis-master的Redis主节点,两个redis-slave的Redis从节点,以及3个redis-sentinel的Redis哨兵实例。

4. 创建一个名为sentinel.conf的配置文件,其中包含有关哨兵的配置信息。并将配置文件分别放到sentinel的conf目录下

sentinel monitor mymaster redis-master 6379 2
sentinel down-after-milliseconds mymaster 5000
sentinel failover-timeout mymaster 10000
sentinel resolve-hostnames yes

这个配置文件告诉哨兵监视名为mymaster的主节点,并在主节点不可用时触发故障转移。

下面是最终目录结构:

使用Docker Compose搭建Redis哨兵架构,java,redis,docker

5. 确保在创建docker-compose.yml文件和sentinel.conf配置文件之后,使用以下命令启动容器:

docker-compose up -d

使用Docker Compose搭建Redis哨兵架构,java,redis,docker

docker ps查看创建了一个Redis哨兵架构,包括一个主节点、一个从节点和一个哨兵实例。

使用Docker Compose搭建Redis哨兵架构,java,redis,docker

 

  1.  我们创建一个文件夹用于存放相关数据及配置文件。

    /opt/docker/redis/sentinel
  2. 在文件下分别创建Redis及sentinel示例的目录,我这里为了简单省略了Redis实例的配置。并给与目录读写权限。

验证故障转移主从切换

1. 首先我们看下Redis主从是否正常,进入容器:

docker exec -it redis-master redis-cli

使用Docker Compose搭建Redis哨兵架构,java,redis,docker

  输入info我们看下主从状态:

使用Docker Compose搭建Redis哨兵架构,java,redis,docker

2. 停止redis-master实例

docker stop redis-master

3. 观察sentinel状态,可以看到主从切换到172.18.0.2这个实例了。

使用Docker Compose搭建Redis哨兵架构,java,redis,docker

  这里我们看下Redis实例的IP,172.18.0.2reids-slave1的IP。

    

使用Docker Compose搭建Redis哨兵架构,java,redis,docker

    

4. 然后我们进入redis-slave1容器查看状态

docker exec -it redis-slave1 redis-cli

    输入info我们看下主从状态:可以看到主从已经同步了。

使用Docker Compose搭建Redis哨兵架构,java,redis,docker

至此Redis哨兵我们已经搭建好了。文章来源地址https://www.toymoban.com/news/detail-825499.html

到了这里,关于使用Docker Compose搭建Redis哨兵架构的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

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

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

相关文章

  • 使用Docker-Compose搭建Redis集群

    3主+3从 由于仅用于测试,故我这里只用1台服务器进行模拟 redis列表 在server上创建一个目录用于存放redis集群部署文件。这里我放的路径为/root/redis-cluster 在/opt/docker/redis-cluster目录下创建redis-1,redis-2,redis-3,redis-4,redis-5,redis-6文件夹 注意:port值不能都为6379,根据上面redis列表设

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

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

    2024年02月06日
    浏览(41)
  • 一份详细 redis sentinel 哨兵架构搭建步骤<写于2023-04-06>

    redis 哨兵架构,其实是在 主从架构 基础上延伸的,sentinel 哨兵模式的 redis 实例,不提供读写操作的。实例相互之间,会感知到。 code: port 26379 daemonize yes # 改为后台启动 pidfile “/var/run/redis‐sentinel‐26379.pid” logfile “26379.log” dir “/usr/local/redis‐5.0.3/data” #sentinel monitor

    2023年04月14日
    浏览(37)
  • docker-compose搭建redis服务

    2024年02月14日
    浏览(48)
  • 【Redis从头学-12】Redis主从复制和读写分离的多种部署方式解析(普通方式、Docker搭建方式、Docker-Compose搭建方式)

    🧑‍💻作者名称:DaenCode 🎤作者简介:啥技术都喜欢捣鼓捣鼓,喜欢分享技术、经验、生活。 😎人生感悟:尝尽人生百味,方知世间冷暖。 📖所属专栏:Redis从头学 应用 版本/型号 服务器 腾讯云轻量服务器 镜像 Centos 7.6 Docker 1.13.1 Redis redis-6.2.1 Docker-Compose 1.29.2 Redis发生

    2024年02月11日
    浏览(48)
  • docker-compose安装和使用(自启、redis、mysql、rabbitmq、activemq、es、nginx、java应用)

    1.在线安装docker-compose: 参考官网:https://docs.docker.com/compose/install/other/ docker-compose安装及简单入门 [Docker] docker-compose使用教程 Docker系列教程22-docker-compose.yml常用命令 2、离线安装docker-compose: 参考:Docker - 离线安装 docker-compose(以CentOS系统为例) (1)首先访问 docker-compose 的

    2024年02月05日
    浏览(55)
  • 【Redis专题】Redis持久化、主从与哨兵架构详解

    【持久化】这个单词我想大家都不陌生吧。什么是持久化?我们知道,Redis的数据是存储在内存里面的,所以在Redis这里,其实是指把内存中的数据,通过一些策略写到磁盘中,方便因为宕机、或者重启Redis服务的时候,再次把数据加载到内存中。 那么,Redis中持久化策略(方

    2024年02月09日
    浏览(38)
  • 使用docker/docker-compose通过自定义的redis.conf文件启动redis 7.2.3,附上docker-compose.yml的redis配置

    目录 一.复制以及使用自定义的redis.conf文件 1.在官网拷贝对应版本的配置文件内容新建redis.conf文件进行粘贴。(推荐) 2.也可以去官网下载对应版本的redis的tar.gz包,解压后在根目录下找到redis.conf文件复制也可也可。 二.配置redis.conf文件(这里有个小坑) 1.注释掉bind 127.0.0.1

    2024年02月03日
    浏览(59)
  • Redis——哨兵模式(docker部署redis哨兵)+缓存穿透和雪崩

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

    2024年02月12日
    浏览(35)
  • Redis 架构深入:主从复制、哨兵到集群

    大家好,我是小康,今天我们来聊下 Redis 的几种架构模式,包括 主从复制、哨兵和集群模式 。 设想一下,你的咖啡馆在城市中太受欢迎,导致每天都人满为患。为了缓解这种压力,你决定在其他地方开设分店,这样顾客就可以在附近的分店享受咖啡,而不必涌向一个地方,

    2024年03月10日
    浏览(78)

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包