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 。

相关推荐
KmSH8umpK2 小时前
Redis分布式锁进阶第十七篇
数据库·redis·分布式
我是唐青枫3 小时前
别只会用 MemoryCache!C#.NET CacheManager 详解:多级缓存、Region 与 Redis 实战
缓存·c#·.net
重生之小比特3 小时前
【MySQL 数据库】表的操作
数据库·mysql
雷工笔记4 小时前
MES 系统 设备保养管理模块详细设计方案
运维·数据库
晚风_END6 小时前
Linux|操作系统|zfs文件系统的使用详解
linux·运维·服务器·数据库·postgresql·性能优化·宽度优先
晚风_END12 小时前
Linux|操作系统|最新版openzfs编译记录
linux·运维·服务器·数据库·spring·中间件·个人开发
dLYG DUMS13 小时前
DBeaver连接本地MySQL、创建数据库表的基础操作
数据库·mysql
恼书:-(空寄13 小时前
Redisson 原理与最佳实践
redis·分布式锁·redisson
苍煜13 小时前
MySQL分库分表和ES到底怎么选?
数据库·mysql·elasticsearch