手拉手教你搭建redis集群(redis cluster)
csdh11 2025-05-11 14:48 5 浏览
背景:
最近需要使用redis存储数据,但是随着时间的增加,发现原本的单台redis已经不满足要求了,于是就倒腾了一下搭建redist cluster redis集群。
好了,话不多说,下面开始展示:
准备材料:
- 6台服务器,centos7
- xshell
- 文本编辑器
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...
- 一周热门
- 最近发表
- 标签列表
-
- mydisktest_v298 (34)
- document.appendchild (35)
- 头像打包下载 (61)
- acmecadconverter_8.52绿色版 (39)
- word文档批量处理大师破解版 (36)
- server2016安装密钥 (33)
- mysql 昨天的日期 (37)
- parsevideo (33)
- 个人网站源码 (37)
- centos7.4下载 (33)
- mysql 查询今天的数据 (34)
- intouch2014r2sp1永久授权 (36)
- 先锋影音源资2019 (35)
- jdk1.8.0_191下载 (33)
- axure9注册码 (33)
- pts/1 (33)
- spire.pdf 破解版 (35)
- shiro jwt (35)
- sklearn中文手册pdf (35)
- itextsharp使用手册 (33)
- 凯立德2012夏季版懒人包 (34)
- 冒险岛代码查询器 (34)
- 128*128png图片 (34)
- jdk1.8.0_131下载 (34)
- dos 删除目录下所有子目录及文件 (36)