redis集群的创建安装与配置,以及维护

一、redis集群配置

port 7000

cluster-enabled yes

cluster-config-file nodes.conf

cluster-node-timeout 5000

appendonly yes

二、安装ruby(ruby可以充当redis客户端的角色)

yum -y install ruby ruby-devel rubygems rpm-build

gem install redis

三、创建redis集群

1、依次启动node1:7000/7001, node2:7000/7001, node3:7000/7001

[root@node1 7000]# ../src/redis-server redis.conf

2、# 必须使用IP地址不能使用主机名

src/redis-trib.rb create --replicas 1 192.168.199.238:7000 192.168.199.238:7001 \

192.168.199.134:7000 192.168.199.134:7001 192.168.199.237:7000 192.168.199.237:7001

四、启动redis集群

1、 检查

[root@node1 redis]# src/redis-cli -c -h 192.168.0.31 -p 7000 cluster nodes

ebda3f1dad0da2996df119182eab46ed7abedcd9 192.168.0.35:7001 slave 490354a9f25120ee5ae10acc681dc412864ecb03 0 1522055848174 6 connected

490354a9f25120ee5ae10acc681dc412864ecb03 192.168.0.35:7000 master - 0 1522055850183 5 connected 10923-16383

d1a11bf4cc508a11f71d9a40e0aca6c7e491a3c4 192.168.0.33:7000 master - 0 1522055847170 3 connected 5461-10922

c9b21659527f7ce2f234102c4d6b6361e270e5a8 192.168.0.31:7001 slave d1a11bf4cc508a11f71d9a40e0aca6c7e491a3c4 0 1522055849178 3 connected

34604603c5b970b98f0d8351e8811f2688a9c83e 192.168.0.31:7000 myself,master - 0 0 1 connected 0-5460

22c867aa1f70b4cc0ea5c3ca011dd1a2df7da66e 192.168.0.33:7001 slave 34604603c5b970b98f0d8351e8811f2688a9c83e 0 1522055845161 4 connected

2、测试

[root@node1 redis]# src/redis-cli -c -h 192.168.0.31 -p 7000

五、集群扩容

1、增加主节点

# 新节点:192.168.0.31:7002

# 老节点:192.168.0.31:7000

src/redis-trib.rb add-node 192.168.0.31:7002 192.168.0.31:7000

2、增加从节点

# 新节点:192.168.0.31:7002

# 老节点:192.168.0.31:7000

src/redis-trib.rb add-node --slave --master-id 5da7b4b37f4e14638d9558e66166c042b752d417 192.168.0.31:7002 192.168.0.31:7000

六、redis   重新分配redis资源即重新分配槽位

# 老节点:192.168.0.31:7000

src/redis-trib.rb reshard 192.168.0.31:7000

How many slots do you want to move (from 1 to 16384)? 1000 //设置slot数1000 

What is the receiving node ID?  03ccad2ba5dd1e062464bc7590400441fafb63f2 //新节点node id 

Please enter all the source node IDs. 

 Type 'all' to use all the nodes as source nodes for the hash slots. 

 Type 'done' once you entered all the source nodes IDs.  

Source node #1:all //表示全部节点重新洗牌 

Do you want to proceed with the proposed reshard plan (yes/no)?  yes //确认重新分

七、redis集群缩容

1、删除从节点

# 老节点:192.168.0.31:7001

src/redis-trib.rb del-node 192.168.0.31:7001 '9c240333476469e8e2c8e80b089c48f389827265' 

2、删除主节点

1. 删除从节点(注意:需要将从节点转移到其他主节点)

49ed626134079dc301f586ff4edb1670a3a42a8c 被删除主节点ID

192.168.0.31:7000> cluster replicate 49ed626134079dc301f586ff4edb1670a3a42a8c

3. 取消槽位

src/redis-trib.rb reshard 192.168.0.31:7000 // 重新分配槽位

How many slots do you want to move (from 1 to 16384)? 1000 // 被删除master的所有slot数量 

What is the receiving node ID? 5d8ef5a7fbd72ac586bef04fa6de8a88c0671052 // 接收slot的master 

Please enter all the source node IDs. 

 Type 'all' to use all the nodes as source nodes for the hash slots. 

 Type 'done' once you entered all the source nodes IDs. 

Source node #1:49ed626134079dc301f586ff4edb1670a3a42a8c  //被删除master的node-id 

Source node #2:done  

Do you want to proceed with the proposed reshard plan (yes/no)? yes // 取消slot后,reshard

3. 删除主节点

src/redis-trib.rb del-node 192.168.0.31:7000 '49ed626134079dc301f586ff4edb1670a3a42a8c'

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

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

相关文章

Redis---------实现商品秒杀业务,包括唯一ID,超卖问题,分布式锁

订单ID必须是唯一 唯一ID构成: 代码生成唯一ID: import org.springframework.data.redis.core.StringRedisTemplate; import org.springframework.stereotype.Component; import java.time.LocalDateTime; import java.time.ZoneOffset; import java.tim…

【论文阅读】Learning Texture Transformer Network for Image Super-Resolution

Learning Texture Transformer Network for Image Super-Resolution 论文地址Abstract1. 简介2.相关工作2.1单图像超分辨率2.2 Reference-based Image Super-Resolution 3. 方法3.1. Texture TransformerLearnable Texture Extractor 可学习的纹理提取器。Relevance Embedding.…

Qt QImageWriter类介绍

1.简介 QImageWriter 用于写入图像文件的类。它提供了将 QImage 对象保存到不同图像格式文件的功能,包括但不限于 PNG、JPEG、BMP 等。QImageWriter 可以将图像写入文件,也可以写入任何 QIODevice,如 QByteArray,这使得它非常灵活…

python中type,object,class 三者关系

type,object,class 三者关系 在python中&#xff0c;所有类的创建关系遵循&#xff1a; type -> int -> 1 type -> class -> obj例如&#xff1a; a 1 b "abc" print(type(1)) # <class int> 返回对象的类型 print(type(int)) …

基于OpenCv的图像金字塔

⚠申明&#xff1a; 未经许可&#xff0c;禁止以任何形式转载&#xff0c;若要引用&#xff0c;请标注链接地址。 全文共计3077字&#xff0c;阅读大概需要3分钟 &#x1f308;更多学习内容&#xff0c; 欢迎&#x1f44f;关注&#x1f440;【文末】我的个人微信公众号&#xf…

【讲解如何OpenCV入门】

&#x1f308;个人主页: 程序员不想敲代码啊 &#x1f3c6;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f44d;点赞⭐评论⭐收藏 &#x1f91d;希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff0c;让我们共…

需求规格说明书编制书(word原件)

1 范围 1.1 系统概述 1.2 文档概述 1.3 术语及缩略语 2 引用文档 3 需求 3.1 要求的状态和方式 3.2 系统能力需求 3.3 系统外部接口需求 3.3.1 管理接口 3.3.2 业务接口 3.4 系统内部接口需求 3.5 系统内部数据需求 3.6 适应性需求 3.7 安全性需求 3.8 保密性需…

GiantPandaCV | FasterTransformer Decoding 源码分析(二)-Decoder框架介绍

本文来源公众号“GiantPandaCV”&#xff0c;仅用于学术分享&#xff0c;侵权删&#xff0c;干货满满。 原文链接&#xff1a;FasterTransformer Decoding 源码分析(二)-Decoder框架介绍 作者丨进击的Killua 来源丨https://zhuanlan.zhihu.com/p/669303360 编辑丨GiantPand…

【Python编程实践1/3】模块

目录 目标 模块 import ​编辑 代码小结 题目 from...import 随机模块 代码小结 randint函数 骰子大战 choice函数 总结 目标 拧一颗螺丝&#xff0c;只会用到螺丝刀&#xff1b;但是修一台汽车&#xff0c;需要一整套汽修的工具。函数就像螺丝刀&#xff0c;可以帮…

python项目==一个web项目,配置模板指定文件清洗规则,调用模板规则清洗文件

代码地址 一个小工具。 一个web项目&#xff0c;配置模板指定文件清洗规则&#xff0c;调用模板规则清洗文件 https://github.com/hebian1994/csv-transfer-all 技术栈&#xff1a; SQLite python flask vue3 elementplus 功能介绍&#xff1a; A WEB tool for cleaning…

JavaScript:Web APIs(三)

本篇文章的内容包括&#xff1a; 一&#xff0c;事件流 二&#xff0c;移除事件监听 三&#xff0c;其他事件 四&#xff0c;元素尺寸与位置 一&#xff0c;事件流 事件流是什么呢&#xff1f; 事件流是指事件执行过程中的流动路径。 我们发现&#xff0c;一个完整的事件执行…

Delta lake with Java--利用spark sql操作数据1

今天要解决的问题是如何使用spark sql 建表&#xff0c;插入数据以及查询数据 1、建立一个类叫 DeltaLakeWithSparkSql1&#xff0c;具体代码如下&#xff0c;例子参考Delta Lake Up & Running第3章内容 import org.apache.spark.sql.SaveMode; import org.apache.spark.…

区域文本提示的实时文本到图像生成;通过一致性自注意力机制的视频生成工具保持视频的一致性;专门为雪佛兰汽车设计的客服聊天机器人

✨ 1: StreamMultiDiffusion StreamMultiDiffusion是首个基于区域文本提示的实时文本到图像生成框架&#xff0c;实现了高速且互动的图像生成。 StreamMultiDiffusion 旨在结合加速推理技术和基于区域的文本提示控制&#xff0c;以克服之前解决方案中存在的速度慢和用户交互性…

约瑟夫问题新解法

前言 又碰到了约瑟夫问题&#xff0c;这样的题目本来用环形链表模拟的话就能做出来。然而&#xff0c;最近新学习了一种做法&#xff0c;实在是有点震惊到我了。无论是思路上&#xff0c;还是代码量上&#xff0c;都是那么的精彩。就想也震惊一下其他人。谁能想到原来模拟出来四…

C/C++程序设计实验报告综合作业 | 小小计算器

本文整理自博主本科大一《C/C程序设计》专业课的课内实验报告&#xff0c;适合C语言初学者们学习、练习。 编译器&#xff1a;gcc 10.3.0 ---- 注&#xff1a; 1.虽然课程名为C程序设计&#xff0c;但实际上当时校内该课的内容大部分其实都是C语言&#xff0c;C的元素最多可能只…

深度解析 Spring 源码:探寻Bean的生命周期

文章目录 一、 Bean生命周期概述二、Bean生命周期流程图三、Bean生命周期验证3.1 代码案例3.2 执行结果 四、Bean生命周期源码4.1 setBeanName()4.2 setBeanFactory()4.3 setApplicationContext()4.4 postProcessBeforeInitialization()4.5 afterPropertiesSet()4.6 postProces…

力扣刷题第1天:消失的数字

大家好啊&#xff0c;从今天开始将会和大家一起刷题&#xff0c;从今天开始小生也会开辟新的专栏。&#x1f61c;&#x1f61c;&#x1f61c; 目录 第一部分&#xff1a;题目描述 第二部分&#xff1a;题目分析 第三部分&#xff1a;解决方法 3.1 思路一&#xff1a;先排序…

十、多模态大语言模型(MLLM)

1 多模态大语言模型&#xff08;Multimodal Large Language Models&#xff09; 模态的定义 模态&#xff08;modal&#xff09;是事情经历和发生的方式&#xff0c;我们生活在一个由多种模态(Multimodal)信息构成的世界&#xff0c;包括视觉信息、听觉信息、文本信息、嗅觉信…

MySQL技能树学习——数据库组成

数据库组成&#xff1a; 数据库是一个组织和存储数据的系统&#xff0c;它由多个组件组成&#xff0c;这些组件共同工作以确保数据的安全、可靠和高效的存储和访问。数据库的主要组成部分包括&#xff1a; 数据库管理系统&#xff08;DBMS&#xff09;&#xff1a; 数据库管理系…

MySQL45讲(一)(40)

回顾binlog_formatstatement STATEMENT 记录SQL语句。日志文件小&#xff0c;节约IO&#xff0c;但是对一些系统函数不能准确复制或不能复制&#xff0c;如now()、uuid()等 在RR隔离级别下&#xff0c;binlog_formatstatement 如果执行insert select from 这条语句是对于一张…