Redis集群搭建

本文深入解析Redis-Cluster的工作原理,包括为何选择集群、分布存储机制和槽的概念。通过详细步骤指导如何从零开始搭建Redis集群,涵盖环境准备、集群配置及启动过程。
一 什么是Redis-Cluster
      为何要搭建Redis集群。Redis是在内存中保存数据的,而我们的电脑一般内存都不大,这也就意味着Redis不适合存储大数据,适合存储大数据的是Hadoop生态系统的Hbase或者是MogoDB。Redis更适合处理高并发,一台设备的存储能力是很有限的,但是多台设备协同合作,就可以让内存增大很多倍,这就需要用到集群。
        Redis集群搭建的方式有多种,例如使用客户端分片、Twemproxy、Codis等,但从redis 3.0之后版本支持redis-cluster集群,它是Redis官方提出的解决方案,Redis-Cluster采用无中心结构,每个节点保存数据和整个集群状态,每个节点都和其他所有节点连接。客户端与 redis 节点直连,不需要中间 proxy 层.客户端不需要连接集群所有节点连接集群中任何一个可用节点即可。所有的 redis 节点彼此互联(PING-PONG 机制),内部使用二进制协议优化传输速度和带宽.

二 分布存储机制-槽
        (1)redis-cluster 把所有的物理节点映射到[0-16383]slot 上,cluster 负责维护
                node<->slot<->value
        (2)Redis 集群中内置了 16384 个哈希槽,当需要在 Redis 集群中放置一个 key-value时,redis先对key使用crc16算法算出一个结果,然后把结果对 16384 求余数,           这样每个key 都会对应一个编号在 0-16383 之间的哈希槽,redis 会根据节点数量大致均等的将哈希槽映射到不同的节点。
                例如三个节点:槽分布的值如下:
                SERVER1:  0-5460
                SERVER2:  5461-10922
                SERVER3:  10923-16383

三 搭建Redis-Cluster
        1 搭建要求
        需要 6 台 redis 服务器。搭建伪集群。
        需要 6 个 redis 实例。
        需要运行在不同的端口 7001-7006
        2 准备工作
                (1)安装gcc 【此步省略】
                Redis 是 c 语言开发的。安装 redis 需要 c 语言的编译环境。如果没有 gcc 需要在线安装。
                yum install gcc-c++
                (2)使用yum命令安装 ruby  (我们需要使用ruby脚本来实现集群搭建)【此步省略】
                yum install ruby
                yum install rubygems
                (3)将redis源码包上传到 linux 系统  ,解压redis源码包
                (4)编译redis源码  ,进入redis源码文件夹
                        make
                        看到以下输出结果,表示编译成功
                (5)创建目录/usr/local/redis-cluster目录,  安装6个redis实例,分别安装在以下目录
                        /usr/local/redis-cluster/redis-1
                        /usr/local/redis-cluster/redis-2
                        /usr/local/redis-cluster/redis-3
                        /usr/local/redis-cluster/redis-4
                        /usr/local/redis-cluster/redis-5
                        /usr/local/redis-cluster/redis-6
                        以第一个redis实例为例,命令如下
                        make install PREFIX=/usr/local/redis-cluster/redis-1
                        出现此提示表示成功,按此方法安装其余5个redis实例
                (6)复制配置文件  将 /redis-3.0.0/redis.conf 复制到redis下的bin目录下
                [root@localhost redis-3.0.0]# cp redis.conf /usr/local/redis-cluster/redis-1/bin
                [root@localhost redis-3.0.0]# cp redis.conf /usr/local/redis-cluster/redis-2/bin
                [root@localhost redis-3.0.0]# cp redis.conf /usr/local/redis-cluster/redis-3/bin
                [root@localhost redis-3.0.0]# cp redis.conf /usr/local/redis-cluster/redis-4/bin
                [root@localhost redis-3.0.0]# cp redis.conf /usr/local/redis-cluster/redis-5/bin
                [root@localhost redis-3.0.0]# cp redis.conf /usr/local/redis-cluster/redis-6/bin

        3配置集群
                (1)修改每个redis节点的配置文件redis.conf
                修改运行端口为7001 (7002 7003 .....)
                将cluster-enabled yes 前的注释去掉(632行)
                (2)启动每个redis实例
                以第一个实例为例,命令如下
                cd /usr/local/redis-cluster/redis-1/bin/
                ./redis-server redis.conf
                把其余的5个也启动起来,然后查看一下是不是都启动起来了
                [root@localhost ~]# ps -ef | grep redis
                root     15776 15775  0 08:19 pts/1    00:00:00 ./redis-server *:7001 [cluster]
                root     15810 15784  0 08:22 pts/2    00:00:00 ./redis-server *:7002 [cluster]
                root     15831 15813  0 08:23 pts/3    00:00:00 ./redis-server *:7003 [cluster]
                root     15852 15834  0 08:23 pts/4    00:00:00 ./redis-server *:7004 [cluster]
                root     15872 15856  0 08:24 pts/5    00:00:00 ./redis-server *:7005 [cluster]
                root     15891 15875  0 08:24 pts/6    00:00:00 ./redis-server *:7006 [cluster]
                root     15926 15895  0 08:24 pts/7    00:00:00 grep redis
                (3)上传redis-3.0.0.gem ,安装 ruby用于搭建redis集群的脚本。
                [root@localhost ~]# gem install redis-3.0.0.gem
                Successfully installed redis-3.0.0
                1 gem installed
                Installing ri documentation for redis-3.0.0...
                Installing RDoc documentation for redis-3.0.0...
                (4)使用 ruby 脚本搭建集群。
                进入redis源码目录中的src目录  执行下面的命令
                ./redis-trib.rb create --replicas 1 192.168.25.140:7001 192.168.25.140:7002 192.168.25.140:7003
                192.168.25.140:7004 192.168.25.140:7005 192.168.25.140:7006
                出现下列提示信息
                        >>> Creating cluster
                        Connecting to node 192.168.25.140:7001: OK
                        Connecting to node 192.168.25.140:7002: OK
                        Connecting to node 192.168.25.140:7003: OK
                        Connecting to node 192.168.25.140:7004: OK
                        Connecting to node 192.168.25.140:7005: OK
                        Connecting to node 192.168.25.140:7006: OK
                        >>> Performing hash slots allocation on 6 nodes...
                        Using 3 masters:
                        192.168.25.140:7001
                        192.168.25.140:7002
                        192.168.25.140:7003
                        Adding replica 192.168.25.140:7004 to 192.168.25.140:7001
                        Adding replica 192.168.25.140:7005 to 192.168.25.140:7002
                        Adding replica 192.168.25.140:7006 to 192.168.25.140:7003
当前,全球经济格局深刻调整,数字化浪潮席卷各行各业,智能物流作为现代物流发展的必然趋势和关键支撑,正迎来前所未有的发展机遇。以人工智能、物联网、大数据、云计算、区块链等前沿信息技术的快速迭代与深度融合为驱动,智能物流不再是传统物流的简单技术叠加,而是正在经历一场从自动化向智能化、从被动响应向主动预测、从信息孤岛向全面互联的深刻变革。展望2025年,智能物流系统将不再局限于提升效率、降低成本的基本目标,而是要构建一个感知更全面、决策更精准、执行更高效、协同更顺畅的智慧运行体系。这要求我们必须超越传统思维定式,以系统化、前瞻性的视角,全面规划和实施智能物流系统的建设。本实施方案正是基于对行业发展趋势的深刻洞察和对未来需求的精准把握而制定。我们的核心目标在于:通过构建一个集成了先进感知技术、大数据分析引擎、智能决策算法和高效协同平台的综合智能物流系统,实现物流全链路的可视化、透明化和智能化管理。这不仅是技术层面的革新,更是管理模式和服务能力的全面提升。本方案旨在明确系统建设的战略方向、关键任务、技术路径和实施步骤,确保通过系统化部署,有效应对日益复杂的供应链环境,提升整体物流韧性,优化资源配置效率,降低运营成本,并最终为客户创造更卓越的价值体验。我们致力于通过本方案的实施,引领智能物流迈向更高水平,为构建现代化经济体系、推动高质量发展提供强有力的物流保障。
电源题电赛单相并网离网软件硬件锁相环单极性双极性调制等代码及仿真环路计算资料+原理图PCB内容概要:本文档是一份关于电力电子与能源系统仿真研究的技术资料集合,涵盖单相并网/离网系统、软件与硬件锁相环设计、单极性与双极性调制技术、虚拟同步机控制建模、P2G-CCS耦合系统、微电网优化调度、光伏风电联合运行、储能配置及需求响应等多个电力系统核心主题。文档提供了大量基于Matlab/Simulink的代码实现与仿真模型,包括LLC谐振变换器小信号分析、永磁同步电机控制、DC-AC变换器设计、光伏阵列故障仿真、直流微电网建模等,并附有原理图与PCB设计资源。同时整合了智能优化算法(如遗传算法、粒子群、灰狼优化器)、机器学习模型(如LSTM、CNN-GRU-Attention)在负荷预测、故障诊断、路径规划等领域的应用案例,形成一个跨学科的科研资源包。; 适合人群:电气工程、自动化、能源系统及相关专业的研究生、科研人员以及从事电力电子、微电网、新能源控制方向的工程师;具备Matlab/Simulink编程基础和一定电力系统理论知识者更佳。; 使用场景及目标:① 支持电赛或科研项目中对并网逆变器、锁相环、调制策略的设计与验证;② 用于复现高水平论文(如EI/SCI)中的优化调度、控制算法与仿真模型;③ 辅助开展微电网能量管理、储能配置、需求响应策略等课题的研究与代码开发;④ 提供可直接调用的算法模板与仿真平台,提升科研效率。; 阅读建议:建议按照文档结构逐步浏览,优先下载并整理网盘中的完整资源包,结合具体研究方向选取对应代码与模型进行调试与二次开发;对于复杂算法(如NSGA-II、ADMM、MPC),应配合文献理解其数学原理后再实施仿真;关注其中“论文复现”类内容以提升学术研究规范性与技术深度。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值