Redis集群搭建

简介

以前写过一篇搭建 Redis 分片集群的博客,本文介绍使用 Docker 容器的方式搭建 Redis 集群,更简单

搭建

(1)环境介绍

我这有三台 Linux(CentOS7)虚拟机,IP 分别是:

  • 192.168.101.11

  • 192.168.101.15

  • 192.168.101.16

(2)搭建

分别在三台服务器上,执行下面这些命令

shell 复制代码
# 1.创建目录
mkdir /usr/local/dev/redis && cd /usr/local/dev/redis

# 2.创建配置目录
mkdir -p ./redis-cluster/7001 ./redis-cluster/7002

# 3.写入配置
cat > ./redis-cluster/7001/redis.conf << EOF
port 7001
bind 0.0.0.0
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout 5000
appendonly yes
protected-mode no
EOF

cat > ./redis-cluster/7002/redis.conf << EOF
port 7002
bind 0.0.0.0
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout 5000
appendonly yes
protected-mode no
EOF

# 4.启动容器(我这里用 redis-7.0.8 版本)
docker run -d \
  --name redis-7001 \
  --net=host \
  --restart=always \
  -v ./redis-cluster/7001/redis.conf:/usr/local/etc/redis/redis.conf \
  -v ./redis-cluster/7001/data:/data \
  redis:7.0.8 redis-server /usr/local/etc/redis/redis.conf

docker run -d \
  --name redis-7002 \
  --net=host \
  --restart=always \
  -v ./redis-cluster/7002/redis.conf:/usr/local/etc/redis/redis.conf \
  -v ./redis-cluster/7002/data:/data \
  redis:7.0.8 redis-server /usr/local/etc/redis/redis.conf

(3)配置

在任何一台服务器上,敲下面这个命令,进入 Redis 组建集群结构

shell 复制代码
docker exec -it redis-7001 \
redis-cli --cluster create \
192.168.101.11:7001 \
192.168.101.11:7002 \
192.168.101.15:7001 \
192.168.101.15:7002 \
192.168.101.16:7001 \
192.168.101.16:7002 \
--cluster-replicas 1

其中 --cluster-replicas 1 表示主节点、从节点是一比一,即每个主节点分配一个从节点

验证

以上就搭建好了,可以敲下面的命令,查看集群状态、信息

powershell 复制代码
# 1.随便在某一台服务器上进入 Redis 客户端
docker exec -it redis-7001 redis-cli -c -p 7001

# 2.查看集群信息
cluster info

# 3.查看集群的节点信息
cluster nodes

如下,可见集群状态 cluster_state:ok,其中 192.168.101.15 上的两台 Redis,和 192.168.101.11 上的 7002 端口的 Redis 是主节点

在我本地 Windows 系统上,分别连接四个不同的 Redis,主从都有,验证一下读写情况

如下

需要注意的是,以集群方式连接,需要加 -c 参数,如下

powershell 复制代码
redis-cli -c -h 192.168.101.15 -p 7001

验证读写情况

再验证一下停机情况,停掉 192.168.101.11:7001 的 Redis

查看集群节点,可见一个从节点挂机

再启动这个节点,把 192.168.101.11:7002 这个主节点给停掉

可以看到推举出了新的主节点,也就是 192.168.101.16:7001 这个节点

此时,再重启 192.168.101.11:7002,会以从节点的方式加入集群

项目配置

在 Spring Boot 项目中,使用 Redis 集群的配置,配置文件,如下

yml 复制代码
spring:
  redis:
    cluster:
      nodes:
        - 192.168.101.11:7001
        - 192.168.101.11:7002
        - 192.168.101.15:7001
        - 192.168.101.15:7002
        - 192.168.101.16:7001
        - 192.168.101.16:7002

建议把所有节点的地址都加进去,这里的配置不关心是不是主节点,实际上主从关系是时刻变化的,这里固定写死不太现实。

配置文件中写的节点,只是一个进入 Redis 集群的入口,写一个应该都行,

只不过写一个或者少数几个,如下,

yml 复制代码
spring:
  redis:
    cluster:
      nodes:
        - 192.168.101.11:7001
        - 192.168.101.15:7001
        - 192.168.101.16:7001

当这三个节点恰好宕机时,集群还是能提供服务的,但因为这三个 "入口节点" 挂了,项目就用不了 Redis 。

相关推荐
huangdong_7 分钟前
京东商品图片视频批量下载与m3u8视频合并技术完整实现方案
大数据·前端·数据库
倒流时光三十年15 分钟前
PostgreSQL CASE 条件表达式详解
数据库·postgresql
字节跳动数据平台38 分钟前
营销视频进入工业化时代,火山引擎多模态数据湖如何助力多米实现内容生产提效 100+ 倍
数据库
健康平安的活着1 小时前
mysql中数据库脚本太大,通过脚本命令修改db名称
数据库·mysql
伊甸31 小时前
从企业级项目学敏感词过滤:DFA算法与双层缓存实战
java·算法·缓存
倒流时光三十年1 小时前
PostgreSQL COALESCE 条件表达式函数详解
数据库·postgresql
摇滚侠1 小时前
MyBatis 入门到项目实战 MyBatis 的缓存 56-61
java·缓存·mybatis
让我上个超影吧2 小时前
Claude code:Hooks
java·数据库·ai编程
RH2312112 小时前
2026.6.8Linux
java·数据库·中间件
其实防守也摸鱼2 小时前
软件安全与漏洞--Windows底层原理与软件逆向工程基础
linux·网络·数据库·算法·安全·安全架构·软件安全与漏洞