Redis系列之Cluster集群搭建

news/2024/5/19 16:24:45

在上一篇博客,我们学习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 槽中的键

http://www.mrgr.cn/p/23474348

相关文章

使用 ECharts 绘制咖啡店各年订单的可视化分析

使用 ECharts 绘制咖啡店各年订单的可视化分析 在这篇博客中&#xff0c;我将分享一段使用 ECharts 库创建可视化图表的代码。通过这段代码&#xff0c;我们可以直观地分析咖啡店各年订单的情况。 饼图 这段代码包含了两个 ECharts 图表&#xff0c;一个是饼图&#xff0c;用…

vis.js线条3d图形

代码案例<!DOCTYPE html> <html><head><title>Graph 3D demo</title><style>body {font: 10pt arial;}</style><scripttype="text/javascript"src="https://unpkg.com/vis-graph3d@latest/dist/vis-graph3d.min.j…

华为数通HCIA ——企业网络架构以及产品线

一.学习目标&#xff1a;精讲网络技术&#xff0c;可以独立搭建和维护中小企业网络&#xff01; 模拟器&#xff08;华为方向请安装ENSP&#xff0c;Ensp-Lite已有安装包&#xff0c;号称功能更加完善-这意味着要耗费更多的系统资源但是仅对华为内部伙伴申请后方可使用&#x…

Linux RTC驱动深入解析

目录标题 实时时钟&#xff08;RTC&#xff09;基础Linux内核中的RTC框架RTC设备类设备树&#xff08;Device Tree&#xff09; 编写Linux RTC驱动1. 初始化和注册2. RTC设备操作函数3. 清理函数 测试RTC驱动驱动开发的挑战总结 在许多嵌入式系统和服务器上&#xff0c;实时时钟…

一三云:教你小型企业如何选择云服务器

在数字化时代,云服务器已成为小型企业实现数字化转型的关键工具。对于小型企业而言,选择合适的云服务器不仅能够降低IT成本,提高运营效率,还能够确保数据的安全性和业务的连续性。然而,面对市面上众多云服务器提供商和复杂的产品选择,小型企业往往感到困惑和不知所措。本…

深入理解高级加密标准(Advanced Encryption Standard)

title: 深入理解高级加密标准&#xff08;Advanced Encryption Standard&#xff09; date: 2024/4/23 20:04:36 updated: 2024/4/23 20:04:36 tags: AES概述加密原理优势特点算法详解安全性应用实践案例分析 第一章&#xff1a;AES概述 AES的历史和背景 历史&#xff1a; 高…

YOLOV8训练问题

代码如上,效果如下:无限循环打印权重文件修改为如下即可,通过if __name__ == __main__使得代码不会被其余文件循环调用(具体为何被调用不知):

【MySQL 数据宝典】【磁盘结构】- 005 Undo log 撤销日志

一、基本介绍 ​ 每当我们要对一条记录做改动时&#xff08;这里的改动可以指 INSERT 、 DELETE 、 UPDATE &#xff09;&#xff0c;都需要留一手 -> 把回滚时所需的东西都给记下来 ​ 你插入一条记录时&#xff0c;至少要把这条记录的主键值记下来&#xff0c;之后回滚的…

maven仓库下载不下来的包如何自己安装(本地宝导入到maven仓库)

1.下载jar包 https://mvnrepository.com/ 在官网上搜索jar包,点击下载2.将jar包放在一个没有中文的路径下(我放在了D盘根路径下) 打开CMD框执行下面的命令 mvn install:install-file -Dfile=D:\kingbase8-8.6.0.jar -DgroupId=com.kingbase -DartifactId=kingbase8 -Dversio…

在PostgreSQL中如何实现递归查询,例如使用WITH RECURSIVE构建层次结构数据?

文章目录 解决方案使用WITH RECURSIVE进行递归查询示例代码 总结 在PostgreSQL中&#xff0c;递归查询是一种非常强大的工具&#xff0c;它可以用来查询具有层次结构或树形结构的数据。例如&#xff0c;你可能会在员工-经理关系、目录结构或组织结构图中遇到这样的数据。为了处…

ZStack教育云计算解决方案入选高质量数字化转型技术解决方案集

近日&#xff0c;中国信通院“铸基计划”《高质量数字化转型技术解决方案&#xff08;2023年度&#xff09;》&#xff08;以下简称“方案集”&#xff09;发布&#xff0c;云轴科技ZStack智慧教育云计算解决方案入选《高质量数字化转型技术解决方案集》。 为促进数字化转型相…

HarmonyOS NEXT 实战开发—Grid和List内拖拽交换子组件位置

本示例分别通过onItemDrop()和onDrop()回调,实现子组件在Grid和List中的子组件位置交换。介绍 本示例分别通过onItemDrop()和onDrop()回调,实现子组件在Grid和List中的子组件位置交换。 效果图预览使用说明:拖拽Grid中子组件,到目标Grid子组件位置,进行两者位置互换。 拖拽…

An Analysis of Sequential Recommendation Datasets

目录概统计角度论证实验论证代码Woolridge D., Wilner S. and Glick M. An analysis of sequential recommendation datasets. PERSPECTIVES, 2021.概 本文讨论了 MovieLens 系列数据集是否适用于序列推荐. 统计角度论证作者为了论证 MovieLens 不适合作为序列推荐数据集, 首先…

Docker(二十)-Docker容器CPU、memory资源限制

背景 在使用 docker 运行容器时,默认的情况下,docker没有对容器进行硬件资源的限制,当一台主机上运行几百个容器,这些容器虽然互相隔离,但是底层却使用着相同的 CPU、内存和磁盘资源。如果不对容器使用的资源进行限制,那么容器之间会互相影响,小的来说会导致容器资源使用…

Docker(十七)-修改Docker容器启动配置参数

有时候,我们创建容器时忘了添加参数 --restart=always ,当 Docker 重启时,容器未能自动启动,现在要添加该参数怎么办呢,方法有二: 1、Docker 命令修改 docker container update --restart=always 容器名字 2、直接改配置文件 首先停止容器,不然无法修改配置文件 配置文件…

Docker(十四)-Docker四种网络模式

Docker 安装时会自动在 host 上创建三个网络,我们可用 docker network ls 命令查看:none模式,使用--net=none指定,该模式关闭了容器的网络功能。 host模式,使用--net=host指定,容器将不会虚拟出自己的网卡,配置自己的IP等,而是使用宿主机的IP和端口。 bridge模式,使用…

Ubuntu 安装 Harbor

一、安装 docker 原文参考传送门 1st 卸载系统自带的 docker 应用 for pkg in docker.io docker-doc docker-compose docker-compose-v2 podman-docker containerd runc; do sudo apt-get remove $pkg; done 2nd 设置Docker 的apt源 # Add Dockers official GPG key: sudo…

SpanBert学习

SpanBERT: Improving Pre-training by Representing and Predicting Spans 核心点 提出了更好的 Span Mask 方案&#xff0c;也再次展示了随机遮盖连续一段字要比随机遮盖掉分散字好&#xff1b;通过加入 Span Boundary Objective (SBO) 训练目标&#xff0c;增强了 BERT 的性…

流量分析(buuctf版)

1.被嗅探的流量分析题目为文件传输的数据文件传输一般直接找POST(大写)包搜索框搜素http.request.method==POST得到两个包体,其中一个含有图片文件打开含图片的包体向下滑动得到flag,flag为flag{da73d88936010da1eeeb36e945ec4b97}2.easycap翻译为简单的帽子,感觉没什么特…

python包:torchvision

torch 是一个偏向于底层的包, 做一些较为基础 矩阵运算对于不同的样本 比如图像, 声音 ,文字, 之类,有更加针对性的包比如,针对图片 他的矩阵处理专用包就是:torchvision这个就需要 单独安装,这个包的体积不是很大,我们可以直接尝试 安装pip install torchvision…