Redis系列之Cluster集群搭建

在上一篇博客,我们学习Redis哨兵Sentinel集群的搭建,redis的哨兵模式提供了比如监控、自动故障转移等高可用方案,但是这种方案,容量相对固定,要进行持续扩容或者数据分片就不适合,所以有另外一种更复杂的集群方案,Cluster集群模式

实验环境

  • CentOS7
  • Xshell6
  • XFtp6
  • Redis6.2.2

节点准备

Redis Cluster集群模式至少需要三主三从,起码得6个节点,因为没有那么多服务器,所以先用3个节点来做实验,正常大型项目都是需要部署多几个节点,提供系统可用性。

  • 节点1:192.168.65.109 6380
  • 节点2:192.168.65.109 6381
  • 节点3:192.168.66.108 6380
  • 节点4:192.168.66.108 6381
  • 节点5:192.168.66.149 6380
  • 节点6:192.168.66.149 6381

每一个节点部署一个redis,可以配置好一个,然后统一上传即可

# 到对应目录
cd /usr/local
# 创建一个目录
mkdir redis-cluster
# 复制redis-6.2.2安装目录
cp -r /usr/local/redis/redis-6.2.2 /usr/local/redis-cluster/redis-6.2.2-6380 

修改配置

修改redis.conf配置文件

# 修改节点端口
port 6380
# 注释下面这一行
bind 127.0.0.1
# 保护模式改为no,允许外部网络访问
protected-mode no
# 设置后台运行,改为yes
daemonize yes
# 开启集群模式
cluster-enabled yes
# 集群配置文件,根据端口不同修改
cluster-config-file nodes-6380.conf
# pid文件路径配置
pidfile /var/run/redis-6380.pid

启动每个节点的redis

配置好之后,部署每个节点的redis

# 到对应目录
cd /usr/local/redis-cluster/redis-6.2.2-6380/src
# 启动redis
./redis-server ../redis.conf

查看redis是否启动成功

ps -elf | grep redis

在这里插入图片描述

或者查看端口

netstat -lntp | grep 6380

在这里插入图片描述

创建Cluster集群

在任意一个节点创建集群

 ./redis-cli --cluster create 192.168.65.109:6380 192.168.65.109:6381 192.168.66.108:6380 192.168.66.108:6381 192.168.66.149:6380 192.168.66.149:6381 --cluster-replicas 1

在这里插入图片描述
查看集群信息

[root@localhst src]# redis-cli -p 6380
127.0.0.1:6380> cluster nodes

在这里插入图片描述

Cluster自动故障转移

现在模拟一些一个节点出现宕机的情况,192.168.65.109:6380节点关闭,可以看到日志等一会后,原本是slave节点的192.168.66.108:6381节点升级为master节点
在这里插入图片描述
重启一下刚才的192.168.65.109:6380节点,可以看到变成slave节点
在这里插入图片描述

所以,cluster集群是会进行自动故障转移的,还是比较高可用的

集群扩容

连接一个redis客户端,然后add-node第一个参数是要添加的节点,第二个参数是集群里随机的节点

./redis-cli -p 6380 --cluster add-node 192.168.65.109:6382 192.168.65.109:6380

在这里插入图片描述
看看节点是否添加成功

在这里插入图片描述

数据迁移

在上一个步骤,添加好节点后,可以看到节点,但是发现没有分配hash槽
在这里插入图片描述
所以,使用命令

./redis-cli --cluster reshard 192.168.109.6382

在这里插入图片描述

  • 要转移多少槽位的数据
    How many slots do you want to move (from 1 to 16384)? 1-16384之间
  • 输入接收节点id
    What is the receiving node ID? baaf46e193307c6e59e125607c316f7742a8560c,从图可以看出6382的节点id
  • hash槽从哪里拿数据
    假如可以输入192.168.65.109:6380的节点id:219616cbc6bc890cob8b215e4eoa136583f377aa 再后面输入done,回车就会同步对应槽的数据,如果要所有节点,直接输入all即可

集群缩容

要移除节点,也就是集群缩容,可以使用命令移除节点,节点id在cluster nodes查看

./redis-cli --cluster del-node 192.168.65.109:6380 [节点id]

在这里插入图片描述

Cluster其它命令

详细的可以参考官方文档:https://redis.io/commands/?group=cluster

  • 集群相关命令(需要进入客户端)
    • cluster info :打印集群的信息
    • cluster nodes :列出集群当前已知的所有节点,以及这些节点的
      相关信息。
    • cluster meet :将 ip 和 port 所指定的节点添加到集群当中。
    • cluster forget <node_id> :从集群中移除 node_id 指定的节点
    • cluster replicate <node_id> :将当前节点设置为 node_id 指定的节点的
      从节点。
    • cluster saveconfig :将节点的配置文件保存到硬盘里面。
  • 槽slot命令
    • cluster addslots [slot …] :将一个或多个槽(slot)指派(assign)给当前
      节点。
    • cluster delslots [slot …] :移除一个或多个槽对当前节点的指派。
    • cluster flushslots :移除指派给当前节点的所有槽,让当前节点变成一个没有指派任何槽的节点。
    • cluster setslot node <node_id> :将槽 slot 指派给 node_id 指定的节点,如果槽已经指派给另一个节点,那么先让另一个节点删除该槽>,然后再进行指派。
    • cluster setslot migrating <node_id> :将本节点的槽 slot 迁移到 node_id指定的节点中。
    • cluster setslot importing <node_id> :从 node_id 指定的节点中导入槽slot 到本节点。
    • cluster setslot stable :取消对槽 slot 的导入(import)或者迁移(migrate)。
  • 键命令
    • cluster keyslot :计算键 key 应该被放置在哪个槽上。
    • cluster countkeysinslot :返回槽 slot 目前包含的键值对数量。
    • cluster getkeysinslot :返回 count 个 slot 槽中的键

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

线性代数基础3 行列式

行列式 行列式其实在机器学习中用的并不多&#xff0c;一个矩阵必须是方阵&#xff0c;才能计算它的行列式 行列式是把矩阵变成一个标量 import numpy as np A np.array([[1,3],[2,5]]) display(A) print(矩阵A的行列式是&#xff1a;\n,np.linalg.det(A))array([[1, 3],[2, …

视频质量评价 PSNR 算法详细介绍

PSNR PSNR(Peak Signal-to-Noise Ratio,峰值信噪比)是一种常用的评价图像质量的指标,尤其在图像压缩和图像处理领域。它基于最大可能的图像信号功率和图像的噪声功率之间的比率,通常用于衡量图像恢复或图像压缩算法的效果。 原理 PSNR是基于MSE(Mean Squared Error,均…

『 论文解读 』大语言模型(LLM)代理能够自主地利用1 day漏洞,利用成功率竟高达87%,单次利用成本仅8.8美元

1. 概览 该论文主要展示了大语言模型LLM代理能够自主利用现实世界的 1 day 漏洞。研究我发现&#xff0c; GPT-4 在提供了CVE描述的情况下&#xff0c;能够成功利用 87% 的漏洞。 这与其他测试模型&#xff08;如 GPT-3.5 和其他开源 LLM &#xff09;以及开源漏洞扫描器&…

Tomcat核心组件深度解析

Server组件 Service组件 连接器Connector组件 容器Container组件

【hackmyVM】whitedoor靶机

文章目录 信息收集1.IP地址2.端口探测nmapftp服务 3.访问主页 漏洞利用1.反弹shell2.尝试提权3.base64解密 提权1.切换用户2.john爆破3.切换Gonzalo用户4.vim提权 信息收集 1.IP地址 ┌─[✗]─[userparrot]─[~] └──╼ $fping -ag 192.168.9.0/24 2> /dev/null192.168…

【小程序】IOS wx小程序解压获取源文件

根据自己手机的系统&#xff0c;获取wx小程序的缓存目录 一、微信小程序文件存放路径 安卓&#xff1a; /data/data/com.tencent.mm/MicroMsg/{{user哈希值}}/appbrand/pkg/iOS越狱&#xff1a; /User/Containers/Data/Application/{{系统UUID}}/Library/WechatPrivate/{{user…

PCIe复位方式介绍

前言 PCIe总线中定义了四种复位名称&#xff1a;冷复位&#xff08;Cold Reset&#xff09;、暖复位&#xff08;Warm Reset&#xff09;、热复位&#xff08;Hot Reset&#xff09;和功能层复位&#xff08;Function-Level Reset&#xff0c;FLR&#xff09;。其中FLR是PCIe …

RocketMQ学习笔记

kafka适合于日志收集的场景&#xff08;不需要太多topic&#xff1b;topic下面的partition多了会造成写文件的速度变慢&#xff0c;因为要造很多索引&#xff09; RocketMQ更适合于电商场景&#xff08;适用于topic特别多的情况&#xff09; 快速安装RocketMQ RocketMQ的官网…

js 函数节流和函数防抖及区别详解

文章目录 1. 前言2. 函数节流3. 函数防抖4. 总结 1. 前言 浏览器中总是有一些操作非常耗费性能。所以就有了函数节流和函数防抖来提高浏览器性能。 函数节流&#xff1a;频繁触发一个事件时候&#xff0c;每隔一段时间&#xff0c;函数只会执行一次。 函数防抖&#xff1a;当触…

某零售企业招聘管理体系搭建咨询项目

科学岗位分析&#xff0c;改善招聘流程&#xff0c;提高招聘及时率随着公司不断发展壮大&#xff0c;企业规模逐渐增大&#xff0c;部门设置也日益增多&#xff0c;因此对人员的需求也日益提高。但是目前该企业在人员招聘方面逐渐暴露出一些诸如岗位分析不到位、缺乏整体面试计…

Java中对象如何拷贝?

hi&#xff0c;我是程序员王也&#xff0c;一个资深Java开发工程师&#xff0c;平时十分热衷于技术副业变现和各种搞钱项目的程序员~&#xff0c;如果你也是&#xff0c;可以一起交流交流。 今天我们来聊一聊Java中的对象拷贝~ 浅拷贝与深拷贝 在Java中&#xff0c;对象拷贝可…

向量数据库的崛起:如何改变数据存储与机器学习的未来

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…

便携的图像背景去除工具PhotoScissors9.2版本在Windows系统的下载与安装配置

目录 前言一、PhotoScissors安装二、使用配置总结 前言 ​“ PhotoScissors是一个多功能和强大的照片编辑工具&#xff0c;专门为Windows用户寻求一个直观的解决方案&#xff0c;背景删除和图像编辑。作为专用的Windows软件&#xff0c;PhotoScissors提供了一个用户友好的平台…

vlan 和 trunk实验

VLAN&#xff08;Virtual Local Area Network&#xff09;&#xff0c;即虚拟局域网&#xff0c;是一种网络技术&#xff0c;它的主要原理是将物理网络划分为多个逻辑子网&#xff0c;每个子网形成一个独立的广播域。这样&#xff0c;VLAN内的主机间通信就像在同一个局域网内一…

[Java基础揉碎]集合

目录 集合的理解和好处 数组 集合的理解和好处 继承图 ​编辑 简单实例 Collection接口和常用方法 1) add:添加单个元素 2) remove:删除指定元素 3) contains:查找元素是否存在 4) size:获取元素个数 5) isEmpty:判断是否为空 ​编辑 6) clear:清空 7) addAll:添…

碎碎笔记01

凹凸性 一元函数 凸函数&#xff1a;二阶导数>0 f ( x ) x 2 f(x) x^2 f(x)x2的二阶导数是 2&#xff0c;>0凹函数&#xff1a;二阶导数<0 驻点&#xff0c;拐点 驻点&#xff1a;增减性的交替点 拐点&#xff1a;凹凸性的交替点 脑补 f ( x ) s i n x f(x) …

揭阳硕榕超市管理系统的设计与实现(论文)_kaic

摘 要 在互联网高速发展环境下&#xff0c;传统的管理手段无法满足对信息的高效、快速的管理要求。为顺应时代发展的需要&#xff0c;提高超市的管理效能&#xff0c;提高超市的管理速度&#xff0c;构建一个信息化的工作流程&#xff0c;揭阳硕榕超市管理系统应运而生。 根…

spring boot: 使用MyBatis从hive中读取数据

一、hive表&#xff1a; 启动hiveserver2 二、添加mybatis starter和hive依赖 <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instan…

[阅读笔记23][JAM]JOINTLY TRAINING LARGE AUTOREGRESSIVE MULTIMODAL MODELS

这篇论文是24年1月发表的&#xff0c;然后是基于的RA-CM3和CM3Leon这两篇论文。它所提出的JAM结构系统地融合了现有的文本模型和图像生成模型。 主要有两点贡献&#xff0c;第一点是提出了融合两个模型的方法&#xff0c;第二点是为混合模型精心设计的指令微调策略。 下图是一个…

【Arduino IDE 环境配置】

目录 Arduino IDE 环境配置 1. 安装方式2. 操作方法&#xff08;Arduino中文社区&#xff09; 2.1. 安装Arduino IDE2.2. 下载固件2.3. 修改Arduino IDE语言2.4. 添加开发板管理网址2.5. 运行离线包2.6. 检查安装是否成功 下载Arduino IDE&#xff1a; 如果你还没有安装Arduin…