docker搭建redis集群

背景

redis作为缓存,生产中都是使用集群部署,故开发的时候自己搞了个乞丐版集群。

Docker version 25.0.4

Docker Compose version v2.24.7

redis 7.0

目录结构

project-directory/

├── docker-compose.yml

├── config/

│ ├── redis-node-1.conf

│ ├── redis-node-2.conf

│ └── redis-node-3.conf

└── data/

├── redis-node-1/

├── redis-node-2/

└── redis-node-3/

准备redis配置文件

mkdir -p /data/redis
cd /data/redis

xml 复制代码
vi config/redis-node-1.conf

port 7000
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout 5000
appendonly yes
bind 0.0.0.0
protected-mode no
#requirepass yourpassword
xml 复制代码
vi config/redis-node-2.conf

port 7001
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout 5000
appendonly yes
bind 0.0.0.0
protected-mode no
#requirepass yourpassword
xml 复制代码
vi config/redis-node-3.conf

port 7002
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout 5000
appendonly yes
bind 0.0.0.0
protected-mode no
#requirepass yourpassword

准备 docker-compose.yml 配置文件

xml 复制代码
version: "3.9"
services:
  redis-node-1:
    image: redis:7.0
    container_name: redis-node-1
    command: ["redis-server", "/usr/local/etc/redis/redis.conf", "--cluster-enabled", "yes", "--cluster-config-file", "nodes.conf", "--cluster-node-timeout", "5000", "--appendonly", "yes"]
    ports:
      - "7000:7000"
    volumes:
      - ./data/redis-node-1:/data
      - ./config/redis-node-1.conf:/usr/local/etc/redis/redis.conf
    networks:
      - redis-cluster-network

  redis-node-2:
    image: redis:7.0
    container_name: redis-node-2
    command: ["redis-server", "/usr/local/etc/redis/redis.conf", "--cluster-enabled", "yes", "--cluster-config-file", "nodes.conf", "--cluster-node-timeout", "5000", "--appendonly", "yes"]
    ports:
      - "7001:7001"
    volumes:
      - ./data/redis-node-2:/data
      - ./config/redis-node-2.conf:/usr/local/etc/redis/redis.conf
    networks:
      - redis-cluster-network

  redis-node-3:
    image: redis:7.0
    container_name: redis-node-3
    command: ["redis-server", "/usr/local/etc/redis/redis.conf", "--cluster-enabled", "yes", "--cluster-config-file", "nodes.conf", "--cluster-node-timeout", "5000", "--appendonly", "yes"]
    ports:
      - "7002:7002"
    volumes:
      - ./data/redis-node-3:/data
      - ./config/redis-node-3.conf:/usr/local/etc/redis/redis.conf
    networks:
      - redis-cluster-network

networks:
  redis-cluster-network:
    driver: bridge

拉取镜像并启动redis

docker-compose up -d

查看redis容器

docker ps | grep redis

查看每个容器的IP地址

docker inspect redis-node-1 | grep IPAddress

同理:将其他容器的IP一一查出。

创建集群

docker exec -it redis-node-1 redis-cli --cluster create \ 172.19.0.3:7000 172.19.0.2:7001 172.19.0.4:7002 \ --cluster-replicas 0

这里的IP就是上一步查出的,要注意对应容器IP和端口要写对,要和docker-compose.yml配置的内容对上。
这里没有从节点,如果你想添加从节点,语法如下:

docker exec -it redis-node-1 redis-cli --cluster create

<主节点IP>:7000 <主节点IP>:7001 <主节点IP>:7002

<从节点IP>:7003 <从节点IP>:7004 <从节点IP>:7005

--cluster-replicas 1

测试redis

进入容器并登录redis
docker exec -it redis-node-1 redis-cli -c -p 7000

查看集群信息
cluster nodes
cluster info

关闭集群

docker-compose stop

开启集群

docker-compose start

相关推荐
甜可儿18 分钟前
redis序列化设置
数据库·redis
Dontla1 小时前
Docker run --add-host参数解析(在容器启动时向/etc/hosts文件中添加自定义的主机名与IP映射)(适用于临时调试或测试)
tcp/ip·docker·容器
西西小飞龙1 小时前
Docker和K8S中pod、services、container的介绍和关系
docker·容器·kubernetes
元气满满的热码式1 小时前
Docker数据卷操作实战
linux·运维·docker·云原生·容器
kngines1 小时前
【实战 ES】实战 Elasticsearch:快速上手与深度实践-1.3.1单节点安装(Docker与手动部署)
大数据·elasticsearch·docker
千层冷面1 小时前
Redis除了做缓存还能做什么?
数据库·redis·缓存
码有余悸3 小时前
Redis:高性能的键值存储系统
数据库·redis·缓存
老朋友此林10 小时前
浅析 Redis 分片集群 Cluster 原理、手动搭建、动态伸缩集群、故障转移
java·数据库·redis
因兹菜12 小时前
[LeetCode]day29 232.用栈实现队列
redis·算法·leetcode
飞火流星0202712 小时前
docker安装etcd:docker离线安装etcd、docker在线安装etcd、etcd镜像下载、etcd配置详解、etcd常用命令、安装常见问题总结
docker·容器·etcd