百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术教程 > 正文

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

csdh11 2025-05-11 14:48 5 浏览

背景:

最近需要使用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搭建,可以使我们简便很多。参照上面的步骤,你一定可以实现搭建自己的集群。如果有疑问,欢迎留言和私信,我将知无不答。

相关推荐

pdf怎么在线阅读?这几种在线阅读方法看看

pdf怎么在线阅读?我们日常生活中经常使用到pdf文档。这种格式的文档在不同平台和设备上的可移植性,以及保留文档格式和布局的能力都很强。在阅读这种文档的时候,很多人会选择使用在线阅读的方法。在线阅读P...

PDF比对不再眼花缭乱:开源神器diff-pdf助你轻松揪出差异

PDF比对不再眼花缭乱:开源神器diff-pdf助你轻松揪出差异在日常工作和学习中,PDF文件可谓是无处不在。然而,有时我们需要比较两个PDF文件之间的差异,这可不是一件轻松的事情。手动逐页对比简直是...

全网爆火!580页Python编程快速上手,零基础也能轻松学会

Python虽然一向号称新手友好,但对完全零基础的编程小白来讲,总会在很长时间内,都对某些概念似懂非懂,每次拿起书本教程,都要从第一章看起。对于这种迟迟入不了门的情况,给大家推荐一份简单易懂的入门级教...

我的名片能运行Linux和Python,还能玩2048小游戏,成本只要20元

晓查发自凹非寺量子位报道|公众号QbitAI猜猜它是什么?印着姓名、职位和邮箱,看起来是个名片。可是右下角有芯片,看起来又像是个PCB电路板。其实它是一台超迷你的ARM计算机,不仅能够运...

由浅入深学shell,70页shell脚本编程入门,满满干货建议收藏

不会Linux的程序员不是好程序员,不会shell编程就不能说自己会Linux。shell作为Unix第一个脚本语言,结合了延展性和高效的优点,保持独有的编程特色,并不断地优化,使得它能与其他脚本语言...

真工程师:20块钱做了张「名片」,可以跑Linux和Python

机器之心报道参与:思源、杜伟、泽南对于一个工程师来说,如何在一张名片上宣告自己的实力?在上面制造一台完整的计算机说不定是个好主意。最近,美国一名嵌入式系统工程师GeorgeHilliard的名片...

《Linux 命令行大全》.pdf

今天跟大家推荐个Linux命令行教程:《TheLinuxCommandLine》,中文译名:《Linux命令行大全》。该书作者出自自美国一名开发者,兼知名Linux博客LinuxCo...

PDF转换是难题? 搜狗浏览器即开即看

由于PDF文件兼容性相当广泛,越来越多的电子图书、产品说明、公司文告、网络资料、电子邮件选择开始使用这种格式来进行内容的展示,以便给用户更好的再现原稿的细节,但需要下载专用阅读器进行转化才能浏览的问题...

彻底搞懂 Netty 线程模型

点赞再看,养成习惯,微信搜一搜【...

2022通俗易懂Redis的线程模型看完就会

Redis真的是单线程吗?我们一般说Redis是单线程,是指Redis的网络IO和键值对操作是一个线程完成的,这就是Redis对外提供键值存储服务的主要流程。Redis的其他功能,例如持久化、异步删除...

实用C语言编程(第三版)高清PDF

编写C程序不仅仅需要语法正确,最关键的是所编代码应该便于维护和修改。现在有很多介绍C语言的著作,但是本书在这一方面的确与众不同,例如在讨论C中运算优先级时,15种级别被归纳为下面两条原则:需要的...

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

背景:最近需要使用redis存储数据,但是随着时间的增加,发现原本的单台redis已经不满足要求了,于是就倒腾了一下搭建redistclusterredis集群。好了,话不多说,下面开始展示:...

记录处理登录页面显示: HTTP Error 503. The service is unavailable.

某天一个系统的登录页面无法显示,显示ServiceUnavailableHTTPError503.Theserviceisunavailable,马上登录服务器上查看IIS是否正常。...

黑道圣徒杀出地狱破解版下载 免安装硬盘版

游戏名称:黑道圣徒杀出地狱英文名称:SaintsRow:GatOutofHell游戏类型:动作冒险类(ACT)游戏游戏制作:DeepSilverVolition/HighVoltage...

Exchange Server 2019 实战操作指南

...