前端开发入门到精通的在线学习网站

网站首页 > 资源文章 正文

手拉手教你搭建redis集群(redis cluster)

qiguaw 2025-05-08 04:48:58 资源文章 5 ℃ 0 评论

背景:

最近需要使用redis存储数据,但是随着时间的增加,发现原本的单台redis已经不满足要求了,于是就倒腾了一下搭建redist cluster redis集群。

好了,话不多说,下面开始展示:

准备材料:

  1. 6台服务器,centos7
  2. xshell
  3. 文本编辑器

redis集群需要至少要三个master节点,我这里搭建三个master节点,并且为每个master节点再搭建一个slave节点,总共6个redis节点,三主三从。由于服务器有限,下面我使用一台服务器,然后在这台服务器上安装docker。启动6个不同容器的方式,来模拟这6个节点。

安装docker以及docker-compose:

我们先确保服务器能够运行yum操作,如果你的不可以,请先寻求其他的方法解决。然后执行下面命令:

yum install -y docker

等待命令跑完。

验证一下安装,命令:

docker --version

启动docker服务,命令:

systemctl start docker

没有输出则一般表示启动成功,如果你不放心也可以执行systemctl status docker命令查看一下docker的运行状态。如图中所示那样,出现绿色的active (running)表示已经成功启动docker了。

安装docker-compose比较简单,我们只需要执行下面的一段话就行:

curl -L 'https://github.com/docker/compose/releases/download/v2.23.0/docker-compose-linux-x86_64' -o /usr/local/bin/docker-compose

编写脚本:

这一步比较重要,首先我们找个目录,例如我放在/home/cluser目录下。创建该目录的方法是:

mkdir /home/cluster

创建完成之后,再创建6479文件夹:

mkdir /home/cluster/6479

创建完成之后,去到6479目录下,cd /home/cluster/6479。下面创建一个文件,使用命令vim redis.conf,此时会打开编辑器,然后输入i。具体怎么操作,如果你不熟悉,建议先看看vim的使用。然后输入下面的内容,你可以复制下面的内容,然后按下ctrl+shift+insert会粘贴到窗口中:

daemonize no
protected-mode no
port 6479
logfile ""
pidfile /var/run/redis_6479.pid
dir ./
dbfilename dump.rdb
appendonly no
appendfilename "appendonly.aof"
requirepass 123456
masterauth 123456
 
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout 5000

具体这每一行都是什么参数,你可以参考redis官方网站。好了,按下ESC,在输入:wq完成文件的保存。

再创建一个文件docker-compose.yml,参考上面的命令,vim docker-compose.yml。输入下面的代码:

version: '3.3'
services:
  redis6479:
    network_mode: 'host'
    image: redis:6.2.12
    container_name: redis6479
    restart: always
    privileged: true
    volumes:
      - ./data:/data
      - ./redis.conf:/usr/local/etc/redis/redis.conf
      - ./logs:/logs
    command: redis-server /usr/local/etc/redis/redis.conf

保存上面的文件。同理这是docker-compose的文件,想知道怎么写的,可以参考docker-compose官网。

回到上一级的目录下(cd ..),使用命令vim build.sh创建一个新文件,然后输入下面的内容:

#!/bin/bash
cd /home/cluster/6479;
docker-compose up -d;

cd /home/cluster
cp -r 6479 6579;
sed -i "s/6479/6579/g" /home/cluster/6579/docker-compose.yml;
sed -i "s/6479/6579/g" /home/cluster/6579/redis.conf;
cd /home/cluster/6579;
rm -rf data;
rm -rf logs;
docker-compose up -d;

cd /home/cluster
cp -r 6479 6679;
sed -i "s/6479/6679/g" /home/cluster/6679/docker-compose.yml;
sed -i "s/6479/6679/g" /home/cluster/6679/redis.conf;
cd /home/cluster/6679;
rm -rf data;
rm -rf logs;
docker-compose up -d;

cd /home/cluster
cp -r 6479 6779;
sed -i "s/6479/6779/g" /home/cluster/6779/docker-compose.yml;
sed -i "s/6479/6779/g" /home/cluster/6779/redis.conf;
cd /home/cluster/6779;
rm -rf data;
rm -rf logs;
docker-compose up -d;

cd /home/cluster
cp -r 6479 6879;
sed -i "s/6479/6879/g" /home/cluster/6879/docker-compose.yml;
sed -i "s/6479/6879/g" /home/cluster/6879/redis.conf;
cd /home/cluster/6879;
rm -rf data;
rm -rf logs;
docker-compose up -d;

cd /home/cluster
cp -r 6479 6979;
sed -i "s/6479/6979/g" /home/cluster/6979/docker-compose.yml;
sed -i "s/6479/6979/g" /home/cluster/6979/redis.conf;
cd /home/cluster/6979;
rm -rf data;
rm -rf logs;
docker-compose up -d;

保存。要执行build.sh脚本还需要给脚本赋予执行的权限。使用命令chmod +x build.sh。

到此,所有的准备工作完毕!

部署脚本:

得到上面的脚本build.sh之后,我们在脚本的目录下,运行./build.sh。然后等待命令跑完。

待运行完毕之后,我们查看启动的所有的redis容器。使用命令

docker ps -a

创建分布式集群:

上面的步骤是创建了6个不同端口的redis容器,下面我们需要将这些容器真正的用起来,搭建成一个集群。由于我们是3主3从,那么可以执行下面的命令:

docker exec -it redis6479 redis-cli -a 123456 --cluster create --cluster-replicas 1 192.168.1.169:6479 192.168.1.169:6579 192.168.1.169:6679 192.168.1.169:6779 192.168.1.169:6879 192.168.1.169:6979

等待程序自动按照分配好的方案运行。

如果你看到上图,那么恭喜你,redis的三主三从集群,你已经搭建完毕了。

验证:

连接集群中的任意一个节点,执行命令:

docker exec -it redis6479 redis-cli -a 123456 -c -p 6479

查看集群信息:cluster info

查看集群节点:cluster nodes

后记:

借助docker搭建,可以使我们简便很多。参照上面的步骤,你一定可以实现搭建自己的集群。如果有疑问,欢迎留言和私信,我将知无不答。

Tags:

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表