docker-compose redis 集群

docker redis 集群

  • 自定义IP
  • 主从
  • 哨兵
version: '3'
networks:
  redis-net:
    driver: bridge
    ipam:
      config:
        - subnet: "172.22.0.0/24"

services:
  redis1:
    image: redis
    hostname: redis1
    environment: 
      - TZ=Asia/Shanghai
    networks: 
      redis-net: 
        ipv4_address: "172.22.0.2"
    ports:
      - 6379:6379
    volumes: 
      - /Users/mtjmtj7/docker-compose/redis/redis.conf:/usr/local/etc/redis/redis.conf
      - /Users/mtjmtj7/docker-compose/redis/s1/:/usr/local/etc/redis/conf/


  redis2:
    image: redis
    hostname: redis2
    environment: 
      - TZ=Asia/Shanghai
    networks: 
      redis-net: 
        ipv4_address: "172.22.0.3"
    ports:
      - 6389:6379
    volumes: 
      - /Users/mtjmtj7/docker-compose/redis/redis.conf:/usr/local/etc/redis/redis.conf
      - /Users/mtjmtj7/docker-compose/redis/s1/:/usr/local/etc/redis/conf/
    command: 
      - sh
      - -c
      - |
        redis-server --slaveof redis1 6379 &
        redis-sentinel /usr/local/etc/redis/conf/sentinel.conf

  redis3:
    image: redis
    hostname: redis3
    environment: 
      - TZ=Asia/Shanghai
    networks: 
      redis-net: 
        ipv4_address: "172.22.0.4"
    ports:
      - 6399:6379
    volumes: 
      - /Users/mtjmtj7/docker-compose/redis/redis.conf:/usr/local/etc/redis/redis.conf
      - /Users/mtjmtj7/docker-compose/redis/s1/:/usr/local/etc/redis/conf/
    command: 
      - sh
      - -c
      - |
        redis-server --slaveof redis1 6379 &
        redis-sentinel /usr/local/etc/redis/conf/sentinel.conf
Docker Compose 是 Docker 的一个工具,用于定义并管理应用和服务的部署配置。若要在 Docker Compose 中构建 Redis 集群,首先你需要了解 Redis 集群的工作原理,它通常通过主从复制(master-slave replication)或者哨兵模式(sentinel mode)来实现高可用。 以下是使用 Docker Compose 构建 Redis 集群的基本步骤: 1. **定义服务**: 在 `docker-compose.yml` 文件中,定义两个或更多 Redis 实例,每个实例对应一个容器。例如: ```yaml services: redis_master: image: redis:alpine command: "redis-server --cluster-enabled yes" ports: - "6379:6379" redis_slave: image: redis:alpine command: "redis-server --slaveof <master_ip> <master_port>" ``` 确保每个服务名称(如 `redis_master` 和 `redis_slave`)都不同,并且配置 `redis_slave` 指向 `redis_master`。 2. **网络连接**: 创建一个网络,以便容器之间能互相通信,比如 `my-network`: ```yaml networks: my-network: services: ... networks: my-network: aliases: - master - slave ``` 3. **设置环境变量** (仅适用于 sentinel 模式): 如果需要哨兵模式,可以创建一个单独的服务并配置环境变量指向其他 Redis 实例: ```yaml services: redis_sentinel: image: redis:alpine environment: - MASTER_HOST=master - MASTER_PORT=6379 ``` 4. **启动集群**: 使用 `docker-compose up` 命令启动所有服务。 运行过程中,你可以通过调整配置文件来调整集群的规模、复制策略等。需要注意的是,这只是一个基本示例,实际生产环境中可能还需要更多的复杂性和安全措施。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值