部署tendis 集群

news/2025/11/22 15:52:01/文章来源:https://www.cnblogs.com/yg_zhang/p/19256981

1.概述

我们在部署 tendis 集群的时候,我们需要准备 6台机器,3主三从,当然 我们可以将他们部署同一台机器上,只要端口不一样就可以。
我们准备 6个文件夹
端口分别从 7001到 7006

构建过程

2.1.准备6个文件夹

tendis1
tendis2
tendis3
tendis4
tendis5
tendis6

文件夹下放

start.sh
stop.sh
tendisplus.conf

这些文件从 tendis 的 script copy 出来
需要修改
stop.sh

ip=127.0.0.1
port=7001
echo shutdown |../bin/redis-cli -h ${ip} -p ${port}

这个文件修改端口即可
tendisplus.conf ,这个文件也是

port 7001
daemon on
loglevel notice
logdir ./home/log
dumpdir ./home/dump
dir ./home/db
pidfile ./home/tendisplus.pid
slowlog ./home/log/slowlog
rocks.blockcachemb 4096
executorThreadNum 48
cluster-enabled yes

这个文件也是修改端口和是否开启集群

2.2.编写批处理一次性启动6个节点

  • 启动节点
#!/bin/bashecho "Starting all Tendis instances..."# 循环处理 tendis1 到 tendis6
for i in {1..6}; dodir="tendis${i}"if [[ -d "$dir" ]]; thenecho "----------------------------------------"echo "Processing $dir..."# 进入目录,执行脚本,然后返回 (pushd/popd 是另一种方式)( cd "$dir" && echo "In directory: $(pwd)" && ./start.sh )if [[ $? -eq 0 ]]; thenecho "Started $dir successfully."elseecho "Failed to start $dir."fielseecho "Directory $dir not found, skipping."fi
doneecho "----------------------------------------"
echo "All Tendis instance start commands issued."

这样我们可以一次性启动 6个节点

  • 停止节点
#!/bin/bash
echo "Stoping all Tendis instances..."
# 循环处理 tendis1 到 tendis6
for i in {1..6}; dodir="tendis${i}"if [[ -d "$dir" ]]; thenecho "----------------------------------------"echo "Processing $dir..."# 进入目录,执行脚本,然后返回 (pushd/popd 是另一种方式)( cd "$dir" && echo "In directory: $(pwd)" && ./stop.sh )if [[ $? -eq 0 ]]; thenecho "stop $dir successfully."elseecho "Failed to stop $dir."fielseecho "Directory $dir not found, skipping."fi
done
echo "----------------------------------------"
echo "All Tendis instance stop commands issued."

2.3 节点握手

当6个节点启动后,我们可以连到 节点1 和其他的节点握手
连接节点1

redis-cli -p 7001

分别执行

cluster meet 127.0.0.1 7002
cluster meet 127.0.0.1 7003
cluster meet 127.0.0.1 7004
cluster meet 127.0.0.1 7005
cluster meet 127.0.0.1 7006

2.4 分配slots

默认情况下,Tendis存储版跟Redis一样,将所有的数据映射到16384个slot中,每个key都会对应一个槽。只有把slot分配给了Tendis节点,Tendis节点才能响应与slot相关的命令,否则就会返回move错误。

分配slots可使用cluster addslots指令
我们分别将 1,3,5 节点分配 solt
分别登录 7001,7003,7005
连接后分别执行

cluster addslots {0..5461}
cluster addslots {5462..10922}
cluster addslots {10923..16383}

2.5 配置主从复制

我们将1,3,5 作为主节点,2,4,6 作为从 节点
我们先查看节点
登录节点1 执行命令

cluster nodes

看到节点

9474f3e26932126611bf00940ac06fbe9ceb1940 127.0.0.1:7003@17003 master - 0 1763797462000 0 connected 5462-10922
88419aaa88393e14da923f65795266c076cb71f7 127.0.0.1:7001@17001 myself,master - 0 1763797462000 2 connected 0-5461
3dba50eb72c1790fb0109795d92b24457b33e406 127.0.0.1:7005@17005 master - 0 1763797462634 4 connected 10923-16383
8200c98af4c657a681bbd1582a22fc06a86e6c07 127.0.0.1:7004@17004 slave 9474f3e26932126611bf00940ac06fbe9ceb1940 0 1763797461000 3 connected
3b5b89b032a8dc9c1c232da4ee03e1725c750e7a 127.0.0.1:7002@17002 slave 88419aaa88393e14da923f65795266c076cb71f7 0 1763797461579 2 connected
00aa76b24d4d43f48b81893438350914fc10fc1a 127.0.0.1:7006@17006 slave 3dba50eb72c1790fb0109795d92b24457b33e406 0 1763797463680 5 connected

这个是我配置好了的情况,如果没有配置主从的话 6个节点都是主节点。

我们分别登录 2,4,5 执行命令

cluster replicate 4233f87b9899774feb71bcef1cfeec964de0535b
cluster replicate 这里是主节点的ID

2.6 测试

我们可以登录其中的某个节点
执行 set 命令,可以看到他会将key 分布到不同的节点上。
我们连接 tendis 时 需要使用如下命令

./redis-cli -c -p 端口:~/tendis/tendisplus/bin$ ./redis-cli -c -p 7001
127.0.0.1:7001> get name
-> Redirected to slot [5798] located at 127.0.0.1:7003
"小李"

这样集群就配置完成了。

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

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

相关文章

P4555 [国家集训队] 最长双回文串 踢姐

P4555 [国家集训队] 最长双回文串 踢姐 简要题意: 给定一个字符串 \(S\) ,我们定义字符串 \(T\) 的双回文子串为:存在两个字符串 \(X\) 与 \(Y\) 是 \(T\) 的非空子串,满足 \(X\) 与 \(Y\) 无重叠部分并且两个字符…

2025年水肥一体机制造厂权威推荐榜单:便携式水肥一体机/全自动喷淋系统/简易水肥一体源头厂家精选

随着智慧农业的快速推进,水肥一体化技术正成为现代农业生产的关键支撑。据行业数据显示,水肥一体化设备可有效提高水肥利用率30%以上,成为推动农业现代化转型的核心装备。 水肥一体化技术通过集成灌溉与施肥系统,实…

Java—抽象类 - 实践

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

23207225-华辉-第一次blog作业

一. 前言 在完成三次大作业的题集后,我兴高采烈地写下写下这片博客,思考人生的意义,也想和大家分享我在这三次大作业中碰见的问题和个人所得。代码为什么错了?错在哪?该如何才能通过题目的测试点?相信很多同学和…

英语_阅读_AI models_待读

When an artificial intelligence model is created, it doesnt have any knowledge. 当一个人工智能模型被创造出来时,它本身并不具备任何知识。 AI companies like OpenAI teach it different things so that it wo…

11.22组会

11.22组会亚克隆文献讲解 使用好ai是第一重要的 gemini最新版 结合ai搭建工具链 使用可以跨平台共享数据的工具,否则已经落后

2025年食品厂生产用水紫外线消毒设备优质厂家权威推荐榜单:牛奶厂紫外线消毒设备/饮料杀菌紫外线消毒设备/啤酒生产紫外线消毒设备源头厂家精选

在食品安全标准日益严格的今天,紫外线消毒技术凭借其高效灭菌、无化学残留的独特优势,正成为食品生产用水处理的核心环节。 根据全球水处理研究报告显示,紫外线消毒设备在食品饮料行业的应用正快速增长。2025年食品…

2025年福建钨钢棒回收公司权威推荐榜单:福州钨钢合金回收/福建钨钢模具回收/福建钨钢块回收服务商精选

在资源循环利用与绿色制造理念深入人心的背景下,钨钢棒回收作为硬质合金资源再利用的关键环节,其专业化水平直接关系到资源利用效率与企业环保合规。 钨钢棒作为一种高价值硬质合金材料,因其高硬度、耐磨性和耐高温…

扩展RTCM消息 - 教程

扩展RTCM消息 - 教程2025-11-22 15:42 tlnshuju 阅读(0) 评论(0) 收藏 举报pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-f…

java.nio.charset.MalformedInputException: Input length = 1

一 背景 启动nacos微服务报如下错误,检查xml文件,未发现问题,经确定是格式问题 二 解决 java -Dfile.encoding=utf-8 启动项,设置编码格式

线段树问题-从熟练到精通

前言 不是每一个文章都要有前言 但是我的有

完整教程:Flowable工作流引擎:核心表结构概述

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

2025年粗糙轮廓仪厂家权威推荐榜单:轮廓仪/表面轮廓仪/粗糙度轮廓仪源头厂家精选

在制造业迈向精密化与智能化的今天,粗糙轮廓仪以其纳米级的检测精度和广泛的应用领域,已成为质量控制环节不可或缺的设备。 据行业研究报告显示,全球表面粗糙度轮廓仪市场在近年来保持稳定发展态势。预计到2031年,…

使用java实验电梯调度算法

1、前言: 电梯控制系统三次题目集均围绕 Java 实现电梯请求处理与调度逻辑展开,难度逐步递增:第一次搭建基础框架,涉及抽象类、枚举、队列等知识点,6 个组件完成基础运行任务,难度简单,核心是理解同向优先的队头…

2025年刮板蒸发器定做厂家权威推荐榜单:刮板薄膜蒸发器/薄膜蒸发器/刮板式蒸发器装备源头厂家精选

在高浓度、高粘度及热敏性物料的蒸发浓缩领域,刮板蒸发器凭借其独特的传热效率和分离效果,正成为化工、制药、食品等行业的核心设备。 刮板蒸发器通过高速旋转的刮板将物料在加热壁面上刮成薄膜,显著增大传热面积,…

单部电梯调度程序三次迭代设计与实践总结 - 23207231

一、前言 本次共完成三次题目集训练,核心围绕 “单部电梯调度程序” 的迭代开发展开,辅以基础语法与逻辑验证类题目,整体呈现递进式训练节奏。以下从知识点覆盖、题量分布与难度梯度三方面进行总结: (一)知识点覆…

格路计数的一类(降维?)技巧

模拟赛考到了,记录一下。 题面: 给你二维平面上 \(n\) 个点,定义移动:$(x,y) \to (x+1,y) / (x-1,y) / (x,y+1) / (x,y-1) $(一个点可以移动到上下左右与这个点相邻的点)。移动每个点 \(m\) 次,使得最后这些点的…

百度PaddleOCR-VL:基于0.9B超紧凑视觉语言模型,支持109种语言,性能超越GPT-4o等大模型 - 详解

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

hadoop处理mysql数据的性能瓶颈

Hadoop处理MySQL数据时可能会遇到多个性能瓶颈,主要包括以下几个方面:数据导入速度慢:将MySQL中的数据导入Hadoop需要经过抽取、转换和装载(ETL)的过程。如果数据量较大,ETL过程可能会耗费较长时间,导致性能瓶颈…

hadoop在linux的安装

在 Linux 系统上安装 Hadoop 需要以下几个步骤:一、系统环境准备确保你的 Linux 系统满足以下要求:Linux 发行版:如 Ubuntu 20.04 LTS、CentOS 7/8、Debian 11 等。Java:Hadoop 需要 Java 8 或更高版本。磁盘空间:…