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 槽中的键

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

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

相关文章

图像处理的魔法师:Pillow 库探秘

文章目录 图像处理的魔法师&#xff1a;Pillow 库探秘第一部分&#xff1a;背景介绍第二部分&#xff1a;库是什么&#xff1f;第三部分&#xff1a;如何安装这个库&#xff1f;第四部分&#xff1a;库函数使用方法第五部分&#xff1a;场景应用第六部分&#xff1a;常见Bug及解…

YOLOv9改进策略 | 添加注意力篇 | 利用ILSVRC冠军得主SENetV1改善网络模型特征提取能力

一、本文介绍 本文给大家带来的改进机制是SENet&#xff08;Squeeze-and-Excitation Networks&#xff09;其是一种通过调整卷积网络中的通道关系来提升性能的网络结构。SENet并不是一个独立的网络模型&#xff0c;而是一个可以和现有的任何一个模型相结合的模块(可以看作是一…

最新Java面试题3【2024中级】

互联网大厂面试题 1&#xff1a;阿里巴巴Java面试题 2&#xff1a;阿里云Java面试题-实习生岗 3&#xff1a;腾讯Java面试题-高级 4&#xff1a;字节跳动Java面试题 5&#xff1a;字节跳动Java面试题-大数据方向 6&#xff1a;百度Java面试题 7&#xff1a;蚂蚁金服Java…

PyCharm,终端conda环境无法切换的问题(二个解决方案)

问题 PyCharm终端&#xff0c;环境切换无效&#xff0c;默认始终为base 解决一 Settings->Tools->Terminal->ShellPath&#xff0c;将powershell修改为cmd.exe 解决二 conda config --show在输出中找到 auto_activate_base 的行&#xff0c;发现被设置为 true&#x…

HTML作业

作业1: <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title><style>.down…

Android Studio Iguana | 2023.2.1配置优化

一. 前言 本篇文章记录最新版本的Android Studio的配置优化&#xff0c;写这篇文章的是由于电脑中的AS工具更新版本覆盖安装后&#xff0c;AS会经常卡死&#xff0c;Debug的时候也经常莫名其妙的断掉&#xff0c;非常影响工作效率&#xff0c;所以重新把配置环境整理一下&#…

11.事件处理

事件处理 我们可以使用 v-on 指令 (简写为 ) 来监听 DOM 事件&#xff0c;并在事件触发时执行对应的 JavaScript。用法&#xff1a;v-on:click"methodName" 或 click"handler" 事件处理器的值可以是 内联事件处理器&#xff1a;事件被触发时执行的内联 J…

[阅读笔记21][RA-CM3]Retrieval-Augmented Multimodal Language Modeling

这篇论文是meta联合斯坦福在23年4月发表的论文&#xff0c;提出了一个使用外部知识检索增强的多模态模型。 这篇模型提出的RA-CM3模型是第一个能够检索并生成图像文本的多模态模型&#xff0c;在图像文本生成任务上优于现有的多模态模型&#xff0c;同时使用更少的训练量。 RA-…

区间图着色问题:贪心算法设计及实现

区间图着色问题&#xff1a;贪心算法设计及实现 1. 问题定义2. 贪心算法设计2.1 活动排序2.2 分配教室2.3 算法终止 3. 伪代码4. C语言实现5. 算法分析6. 结论7. 参考文献 在本文中&#xff0c;我们将探讨如何使用贪心算法解决一个特定的资源分配问题&#xff0c;即区间图着色问…

物联网实战--驱动篇之(九)NB-IOT(BC260)

目录 一、NB-IOT简介 二、NB-IOT要素 三、代码详解 四、平台端 一、NB-IOT简介 实际上&#xff0c;就是NB-Iot彻底引爆了物联网的&#xff0c;大概2018年左右&#xff0c;NB推广如火如荼&#xff0c;同时广域网、低功耗的LPWAN网络也逐渐传开&#xff0c;现在回头来看&…

Python爬虫爬取中药材价格数据

&#x1f388; 博主&#xff1a;一只程序猿子 &#x1f388; 博客主页&#xff1a;一只程序猿子 博客主页 &#x1f388; 个人介绍&#xff1a;爱好(bushi)编程&#xff01; &#x1f388; 创作不易&#xff1a;喜欢的话麻烦您点个&#x1f44d;和⭐&#xff01; &#x1f388;…

【Leetcode每日一题】 穷举vs暴搜vs深搜vs回溯vs剪枝_全排列 - 全排列(难度⭐⭐)(62)

1. 题目解析 题目链接&#xff1a;46. 全排列 这个问题的理解其实相当简单&#xff0c;只需看一下示例&#xff0c;基本就能明白其含义了。 2.算法原理 回溯算法是一种通过探索所有可能的候选解来找出所有解的算法。当候选解被确认不是一个解&#xff08;或者至少不是最后一…

包装类的认识

前言~&#x1f973;&#x1f389;&#x1f389;&#x1f389; hellohello~&#xff0c;大家好&#x1f495;&#x1f495;&#xff0c;这里是E绵绵呀✋✋ &#xff0c;如果觉得这篇文章还不错的话还请点赞❤️❤️收藏&#x1f49e; &#x1f49e; 关注&#x1f4a5;&#x1…

网络编程 -- 简易TCP网络程序

一 字符串回响 1.1 核心功能 字符串回响程序类似于 echo 指令&#xff0c;客户端向服务器发送消息&#xff0c;服务器在收到消息后会将消息发送给客户端&#xff0c;该程序实现起来比较简单&#xff0c;同时能很好的体现 socket 套接字编程的流程。 1.2 程序结构 这个程序我们…

基于Zookeeper 简单实现分布式任务协调组件

优质博文&#xff1a;IT-BLOG-CN 一、什么是 Zookeeper ZooKeeper是一个分布式的&#xff0c;开放源码的分布式应用程序协调服务&#xff0c;是Google的Chubby一个开源的实现&#xff0c;是Hadoop和Hbase的重要组件。 它是一个为分布式应用提供一致性服务的软件&#xff0c;提…

【管理】杨三角模型

企业成功 成功 战略 X 组织能力 1&#xff09;组织能力对于企业的重要性是和战略一样的&#xff1b; 2&#xff09;组织能力必须与战略适配&#xff0c;才能共同造就企业的成功。 员工思维&#xff1a;员工愿不愿意参与战略落地的实践&#xff1f;员工每天所关心、追求和重视的…

【C++】哈希封装map与set

目录 前言&#xff1a; 一&#xff0c;底层哈希结构 1-1&#xff0c;迭代器的封装 1-2&#xff0c;哈希表的封装 二&#xff0c;unordered_map的封装 三&#xff0c;unordered_set的封装 前言&#xff1a; 上一篇文章说明了哈希结构&#xff0c;这一篇文章来说明如何使用…

安装WSL2

PS C:\Users\pc> wsl --set-default-version 2 有关与 WSL 2 关键区别的信息&#xff0c;请访问 https://aka.ms/wsl2操作成功完成。PS C:\Users\pc> wsl --update 正在检查更新。 已安装最新版本的适用于 Linux 的 Windows 子系统。PS C:\Users\pc> wsl --shutdownPS…

PyTorch深度解析:Tensor——神经网络的核心构建块

在深度学习和神经网络的研究与应用中&#xff0c;Tensor&#xff08;张量&#xff09;无疑是一个核心概念。特别是在PyTorch这一强大的深度学习框架中&#xff0c;Tensor更是扮演了举足轻重的角色。本文将深入探讨PyTorch中的Tensor&#xff0c;从其基本定义、特性、操作到实际…