Redis Cluster高可用集群部署

news2025/1/10 17:20:42

​欢迎光临我的博客查看最新文章: https://river106.cn

Redis从3.0开始支持Redis Cluster集群部署,在3.0之前使用哨兵模式来实现Redis集群(利用Sentinel来监控master节点的状态,如果master节点异常,则将其中一台slave切换为master),性能不如Redis Cluster。

本篇博文以Redis 7.0.5为例来搭建Redis Cluster高可用集群。

Redis官网:https://redis.io
Redis下载地址:https://redis.io/download/

1、Redis高可用集群模式

Redis集群是一个由多个主从节点群组成的分布式服务器群,它具有复制、高可用和分片特性。需要将每个节点设置成集群模式,这种集群模式没有中心节点,可水平扩展,可以线性扩展到上万个节点(官方推荐不超过1000个节点)。

2、Redis安装

首先需要安装Redis,请参考文章 CentOS7下Redis7安装。

3、高可用集群部署

Redis集群需要至少三个master节点,这里搭建三个master节点,并且给每个master再搭建一个slave节点,总共6个redis节点,需要用三台机器部署6个redis实例,每台机器一主一从,不过这里为了方便再简化些,使用一台机器部署6个redis实例;

搭建集群的步骤如下:

3.1、配置

1、在第一台机器的/opt/software/redis下创建文件夹redis‐cluster,然后在其下面分别创建6个文件夾7001、7002、7003、7004、7005、7006;

mkdir ‐p /opt/software/redis/redis‐cluster
cd /opt/software/redis/redis‐cluster
mkdir 7001 7002 7003 7004 7005 7006

2、把之前的redis.conf配置文件copy到7001下,修改如下内容:

daemonize yes # 后台启动
port 7001  # 分别对每个机器的端口号进行设置
pidfile /var/run/redis_7001.pid  # 把pid进程号写入pidfile配置的文件
dir /opt/software/redis/redis‐cluster/7001/  # 指定数据文件存放位置,必须要指定不同的目录位置,不然会丢失数据 
cluster‐enabled yes # 启动集群模式
cluster‐config‐file nodes‐7001.conf  # 集群节点信息文件,这里800x最好和port对应上
cluster‐node‐timeout 10000
# bind 127.0.0.1  # bind绑定的是自己机器网卡的ip,内网一般可以不配置bind,注释掉即可
protected‐mode no #关闭保护模式
appendonly yes # 开启AOF

# 如果要设置密码需要增加如下配置:
requirepass 123456   # 设置redis访问密码 
masterauth 123456    # 设置集群节点间访问密码,跟上面一致

再分别将redis.conf配置文件copy至其他文件夹(7002、7003、7004、7005、7006),调整如下配置为对应节点:

port 700x
pidfile /var/run/redis_700x.pid
dir /opt/software/redis/redis‐cluster/700x/
cluster‐config‐file nodes‐700x.conf

3.2、启动各节点

src/redis-server /opt/software/redis/redis-cluster/7001/redis.conf
src/redis-server /opt/software/redis/redis-cluster/7002/redis.conf
src/redis-server /opt/software/redis/redis-cluster/7003/redis.conf
src/redis-server /opt/software/redis/redis-cluster/7004/redis.conf
src/redis-server /opt/software/redis/redis-cluster/7005/redis.conf
src/redis-server /opt/software/redis/redis-cluster/7006/redis.conf

使用 ps -ef | grep redis 查看验证,如下表明各节点启动成功:

3.3、使用redis-cli创建集群

redis5以前的版本集群是依靠ruby脚本redis‐trib.rb实现,现在redis7可以使用redis-cli来创建集群,创建集群前先关闭防火墙:

systemctl stop firewalld # 临时关闭防火墙
systemctl disable firewalld # 禁止开机启动

创建集群:

src/redis-cli -a 123456 --cluster create --cluster-replicas 1 127.0.0.1:7001 127.0.0.1:7002 127.0.0.1:7003 127.0.0.1:7004 127.0.0.1:7005 127.0.0.1:7006

–cluster-replicas 后面的 1 代表每个创建的主服务器节点创建一个从服务器节点,如果没有从,可以设置为0
-a参数 访问服务端密码,如果之前配置了访问密码,这里需要加上-a参数

[root@iZuf6ib0sh7w9e6el7zwlcZ redis-7.0.5]# src/redis-cli -a 123456 --cluster create --cluster-replicas 1 127.0.0.1:7001 127.0.0.1:7002 127.0.0.1:7003 127.0.0.1:7004 127.0.0.1:7005 127.0.0.1:7006
Warning: Using a password with '-a' or '-u' option on the command line interface may not be safe.
>>> Performing hash slots allocation on 6 nodes...
Master[0] -> Slots 0 - 5460
Master[1] -> Slots 5461 - 10922
Master[2] -> Slots 10923 - 16383
Adding replica 127.0.0.1:7005 to 127.0.0.1:7001
Adding replica 127.0.0.1:7006 to 127.0.0.1:7002
Adding replica 127.0.0.1:7004 to 127.0.0.1:7003
>>> Trying to optimize slaves allocation for anti-affinity
[WARNING] Some slaves are in the same host as their master
M: d7fdb82e01378603f58ec808b394417d1fec8f0e 127.0.0.1:7001
   slots:[0-5460] (5461 slots) master
M: 6d50abfd77cb7d7bda6ee2b209e7d8e6029310e7 127.0.0.1:7002
   slots:[5461-10922] (5462 slots) master
M: 07fbd029398efac634cd564ad442d115af55babe 127.0.0.1:7003
   slots:[10923-16383] (5461 slots) master
S: afc23d25b05f5c7c41fa4008cc715e600bed1a9c 127.0.0.1:7004
   replicates 07fbd029398efac634cd564ad442d115af55babe
S: 02e43e0dea2fec5c2742125d46ae3b24070a1478 127.0.0.1:7005
   replicates d7fdb82e01378603f58ec808b394417d1fec8f0e
S: e846487495c506c756b2a604eff2ed0118db44fe 127.0.0.1:7006
   replicates 6d50abfd77cb7d7bda6ee2b209e7d8e6029310e7
Can I set the above configuration? (type 'yes' to accept): yes
>>> Nodes configuration updated
>>> Assign a different config epoch to each node
>>> Sending CLUSTER MEET messages to join the cluster
Waiting for the cluster to join
..
>>> Performing Cluster Check (using node 127.0.0.1:7001)
M: d7fdb82e01378603f58ec808b394417d1fec8f0e 127.0.0.1:7001
   slots:[0-5460] (5461 slots) master
   1 additional replica(s)
S: 02e43e0dea2fec5c2742125d46ae3b24070a1478 127.0.0.1:7005
   slots: (0 slots) slave
   replicates d7fdb82e01378603f58ec808b394417d1fec8f0e
S: afc23d25b05f5c7c41fa4008cc715e600bed1a9c 127.0.0.1:7004
   slots: (0 slots) slave
   replicates 07fbd029398efac634cd564ad442d115af55babe
M: 07fbd029398efac634cd564ad442d115af55babe 127.0.0.1:7003
   slots:[10923-16383] (5461 slots) master
   1 additional replica(s)
S: e846487495c506c756b2a604eff2ed0118db44fe 127.0.0.1:7006
   slots: (0 slots) slave
   replicates 6d50abfd77cb7d7bda6ee2b209e7d8e6029310e7
M: 6d50abfd77cb7d7bda6ee2b209e7d8e6029310e7 127.0.0.1:7002
   slots:[5461-10922] (5462 slots) master
   1 additional replica(s)
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.

3.4、集群验证

连接任一客户端验证:

src/redis-cli -a 123456 -c -p 7001 

‐a访问服务端密码,‐c表示集群模式,-p表示连接端口

进入7001客户端
查看集群信息:

cluster info

127.0.0.1:7001> cluster info
cluster_state:ok
cluster_slots_assigned:16384
cluster_slots_ok:16384
cluster_slots_pfail:0
cluster_slots_fail:0
cluster_known_nodes:6
cluster_size:3
cluster_current_epoch:6
cluster_my_epoch:1
cluster_stats_messages_ping_sent:504
cluster_stats_messages_pong_sent:508
cluster_stats_messages_sent:1012
cluster_stats_messages_ping_received:503
cluster_stats_messages_pong_received:504
cluster_stats_messages_meet_received:5
cluster_stats_messages_received:1012
total_cluster_links_buffer_limit_exceeded:0

查看节点列表:

cluster nodes

127.0.0.1:7001> cluster nodes
02e43e0dea2fec5c2742125d46ae3b24070a1478 127.0.0.1:7005@17005 slave d7fdb82e01378603f58ec808b394417d1fec8f0e 0 1670132260261 1 connected
afc23d25b05f5c7c41fa4008cc715e600bed1a9c 127.0.0.1:7004@17004 slave 07fbd029398efac634cd564ad442d115af55babe 0 1670132259256 3 connected
07fbd029398efac634cd564ad442d115af55babe 127.0.0.1:7003@17003 master - 0 1670132258252 3 connected 10923-16383
e846487495c506c756b2a604eff2ed0118db44fe 127.0.0.1:7006@17006 slave 6d50abfd77cb7d7bda6ee2b209e7d8e6029310e7 0 1670132261264 2 connected
6d50abfd77cb7d7bda6ee2b209e7d8e6029310e7 127.0.0.1:7002@17002 master - 0 1670132258000 2 connected 5461-10922
d7fdb82e01378603f58ec808b394417d1fec8f0e 127.0.0.1:7001@17001 myself,master - 0 1670132260000 1 connected 0-5460

Redis Cluster将所有数据划分为16384个slots(槽位),每个节点负责其中一部分槽位,槽位的信息存储于每个节点中。
可以看出:
7001主节点(当前节点)分配了 0-5460 槽位,
7002主节点分配了 5461-10922 槽位,
7003主节点分配了 10923-16383 槽位。

集群操作:

集群默认会对 key 值使用 crc16 算法进行 hash 得到槽位值:

HASH_SLOT = CRC16(key) mod 16384

当在7001节点执行 set key 123 命令时, 该节点会发现指令的 key 所在的槽位12539非自己管理的槽位,这时它会向客户端发送一个跳转指令携带目标操作的节点地址,告诉客户端去连这个节点去处理数据,如下:

-> Redirected to slot [12539] located at 127.0.0.1:7003

3.5、关闭集群

src/redis‐cli ‐a 123456 -c ‐h 127.0.0.1 ‐p 7001 shutdown
src/redis‐cli ‐a 123456 -c ‐h 127.0.0.1 ‐p 7002 shutdown
src/redis‐cli ‐a 123456 -c ‐h 127.0.0.1 ‐p 7003 shutdown
src/redis‐cli ‐a 123456 -c ‐h 127.0.0.1 ‐p 7004 shutdown
src/redis‐cli ‐a 123456 -c ‐h 127.0.0.1 ‐p 7005 shutdown
src/redis‐cli ‐a 123456 -c ‐h 127.0.0.1 ‐p 7006 shutdown

如果没有设置访问密码, 则省略-a参数

重新启动集群:

1、先关闭集群节点
2、删除集群相关文件
3、启动集群节点
4、创建集群

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/81226.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C语言中的void

文章目录一.void概要二.void应用场景2.1void能定义变量吗?2.2void这个类型有大小吗?2.3void*能定义变量吗?2.4void*使用2.5void*能不能进行对应的指针运算?2.6void和函数返回值2.7函数void类型的参数一.void概要 void就是空的意思…

多种方法帮你解决tomcat项目部署,idea控制台乱码问题

解决在使用Tomcat过程中idea控制台出现的乱码问题 以下将介绍几种方法(都是小编亲测实用的方法),尝试并寻找适合自己的方法即可 由于我已经处理过了乱码问题,我就重新配置一下 (我有效解决的方案是把-Dfile.encoding…

SQL开窗函数之前后函数(LEAD、LAG)

开窗函数 当我们需要进行一些比较复杂的子查询时,聚合函数就会非常的麻烦,因此可以使用开窗函数进行分组再运用函数查询。窗口函数既可以显示聚集前的数据,也可以显示聚集后的数据,可以在同一行中返回基础行的列值和聚合后的结果…

cubeIDE开发, 全面解析cubeMX图形配置工具

一、cubeIDE 集成cubeMX STM32CubeMX是st公司早期产品,现已经成为STM32Cube开发套件的一部分,直接集成到cubeIDE 开发平台省,是一种芯片引脚图形配置工具,可以非常轻松地配置STM32微控制器和微处理器,以及为Arm Cortex…

java+MySQL基于ssm的公文流转关管理系统

在企业的日常管理过程中,公文管理是日常管理中必不可少的组成部分,其管理水平的高低体现了一个企业管理水平的整体状况。一直以来企业使用传统人工的方式管理公文数据,这种管理方式存在着许多缺点,如:效率低、保密性差,另外时间一长,将产生大量的文件和数据,为操作人员带来不少…

python_selenium自动化测试框架

设计思路 本文整理归纳以往的工作中用到的东西,现汇总成基础测试框架提供分享。 框架采用python3 selenium3 PO yaml ddt unittest等技术编写成基础测试框架,能适应日常测试工作需要。 1、使用Page Object模式将页面定位和业务操作分开&#xff0…

cdp4j爬虫自动化学习

cdp4j爬虫自动化学习cdp4j介绍依赖通过识别本地文件进行调试cdp4j介绍 cdp4j是一个Java库,它提供了高级API来通过DevTools协议控制Chrome或Chromium。它可以用于自动使用网页和测试网页。cdp4j默认情况下可以完全运行,但可以配置为运行无头Chrome或Chro…

Spring Cloud Eureka 服务注册中心怎么配置

Eureka,这里是 Spring Cloud Eureka 的简称,是 Spring Cloud Netflix 组件之一。Spring Cloud Netflix 中核心的组件包括了服务治理(Eureka),服务容断(Hystrix),路由(Zuu…

hypermesh和lsdyna联合仿真计算某汽车座椅进行的头冲吸能实验

导读:本案例运用hypermesh和lsdyna联合仿真,主要是针对某座椅进行的头冲吸能实验的仿真计算。这个工况考察座椅背部的塑料件的破坏情况,以及头部模块的加速度情况,达到保护人头部的效果。 本案例用户可以学习到: 1…

大学生程序设计创新实践基地2022年冬季校赛(NPU ACM Winter Contest)

大学生程序设计创新实践基地2022年冬季校赛(NPU ACM Winter Contest) 总述 总体考察对于板子的熟练变换,以及考察离谱地使用python和对getchar()以及EOF的基础掌握程度。 B,D,E是防AK题目。 题解 A死锁 ​ input…

【第九章 SQL优化_插入数据,主键优化,order by优化】

第九章 SQL优化_插入数据,主键优化,order by优化 1.插入数据: (1)insert: (1)批量插入数据: Insert into tb_test values(1,Tom),(2,Cat),(3,Jerry); (2&am…

PyTorch(五)神经网络基础

文章目录Log一、Containers 基本骨架1. Module2. Sequential二、 Convolution Layers 卷积层1. torch.nn.functional① Conv2d2. torch.nn① Conv2d三、Pooling layers 池化层1. nn.MaxPool2d 下采样(最大池化)四、Non-linear Activations 非线性激活1. …

2022CCSP T1最少充电次数

记录第一次CCSP竞赛。一共3题,只做出第一题,用时3h30m(累),ac了开心地吃了个午饭。然而饭饱之后,大脑完全提不起神看着题面昏昏欲睡。第二题是虚拟内存,超级大模拟,刚好这个学期学os…

2023最新SSM计算机毕业设计选题大全(附源码+LW)之java流浪动物救助网站a1wsz

毕业设计也不需要做多高端的程序,毕业设计对于大多数同学来说,为什么感觉到难,最重要的一个原因,那就是理论课到实践课的转变,很多人一下不适应,本能开始拒绝,如果是一个考试,大家都…

ITU、MCC和MNC介绍以及China运营商对照表

相关概念 ITU 国际电信联盟是联合国负责信息通信技术(ICT)事务的专门机构。 国际电联成立于1865年,为了促进国际上通信网络的互联互通。他们进行全球无线电频谱和卫星轨道的划分,制定技术标准以确保实现网络和技术的无缝互连&…

【Docker】30条Docker常用命令图文举例总结

本期目录1. 帮助启动类命令2. 镜像命令2.1 列出镜像2.2 搜索远程库镜像2.3 拉取镜像2.4 查看所占空间2.5 删除镜像2.6 面试题3. 容器命令3.1 新建启动容器1)启动交互式容器3.2 列出当前所有正在运行的容器3.3 退出容器3.4 启动已停止的容器3.5 重启容器3.6 停止容器…

第六章 映射:Mappings

文章目录1、Mapping 简介1.1 mapping 是啥?1.2 如何查看索引映射2、自动映射:dynamic mapping2.1 自动类型推断规则2.2 mapping 的使用禁忌2.3 自动映射器的意义是什么?3、手动映射:Explicit mapping3.1 创建索引的 mapping3.2 修…

电子产品量产工具项目开发中遇到的问题(更新......)

1、找不到tslib.h库的头文件 这是因为找不到tslib库的头文件。 确定工具链中头文件、库文件目录,对于 IMX6ULL ,命令如下 echo main(){}| arm-linux-gnueabihf-gcc -E -v -找到了编译器arm-linux-gnueabihf的include和lib文件夹 /usr/local/arm/gcc-l…

AT155 高压绝缘电阻测试仪 都有哪些功能?

、 高压绝缘电阻测试仪是—款手持式仪表主要用来测量交流/直流电压、 电阻、 短路蜂鸣测试和 绝缘电阻测量。 式高压绝缘电阻测试仪具有4个量程用千绝缘电阻、 AC/DC电压、 电阻和短路蜂鸣测试。 设计达到以下安全标准 .绝缘测试量程O.lMn to 60Gn。…

机器学习 决策树基础 ID3、C4.5、CART

文章目录参考决策树指标基尼系数基础公式公式理解引入划分后的公式划分后公式的理解信息熵、信息增益如何理解信息熵两种指标的对比划分策略ID3定义举例计算各属性的信息增益选取最优属性作划分对子节点作递归划分生成结果ID3的缺点C4.5信息增益率优化缺点CARTCART相较于前两者…