redis集群搭建教程及遇到的问题处理

发布时间 - 2026-01-11 03:07:26    点击率:

这里,在一个Linux虚拟机上搭建6个节点的redis伪集群,思路很简单,一台虚拟机上开启6个redis实例,每个redis实例有自己的端口。这样的话,相当于模拟出了6台机器了,然后在以这6个实例组建redis集群就可以了。

前提:redis已经安装,目录为/usr/local/redis-4.0.1 如不会,可以参考一下文章  windows下安装redis    Linux下安装redis

redis集群是用的ruby脚本,所以要想执行该脚本,需要ruby环境.。对应redis的源码src目录下的redis-trib.rb,redis-trib.rb是redis官方推出的管理redis集群的工具,是基于redis提供的集群命令封装成简单、便捷、实用的操作工具。so

安装ruby环境:

  1.yum install ruby

   

  2.yum install rubygems

   

  3.gem install redis

      

  Centos默认支持ruby到2.0.0,redis需要最低是2.2.2。解决办法是 先安装rvm 再把ruby版本升级到2.3.3 

       1.sudo yum install curl

       2.安装rvm

    curl -L get.rvm.io | bash -s stable 

  3.

   source /usr/local/rvm/scripts/rvm

  4.查看rvm库中已知的ruby版本

    rvm list known

  5.安装一个ruby版本

    rvm install 2.3.3

  6.使用一个ruby版本

    rvm use 2.3.3

  7.卸载一个已知版本

   rvm remove 2.0.0 

  8.查看版本

   ruby --version

  9.再安装redis

   gem install redis

 redis集群搭建

  创建redis-cluster目录,再创建redis-8001,redis-8002,redis-8003节点目录,再把redis-conf分别复制到节点目录下

  

      分别修改节点下redis-conf文件,由于在一台机器(192.16819.129)上,因此每个实例应该有不同的端口;同时,每个实例显然会有自己的存放数据的地方;开启AOF模式;开启集群配置;开启后台模式;

  

  开启redis服务,看看是否能启动。ok没问题。

  

  创建startall.sh脚本(提示permission denied说明权限不足,执行命令chmod 777 startall.sh修改权限)

  

  启动startall.sh脚本

  

  创建stopall.sh脚本

  

  

  创建集群

  接下来,我们要通过Ruby脚本来创建集群了。

    

  可以看到redis-trib.rb具有以下功能:

  1. create :创建集群
  2. check :检查集群
  3. info :查看集群信息
  4. fix :修复集群
  5. reshard :在线迁移slot
  6. rebalance :平衡集群节点slot数量
  7. add-node :将新节点加入集群
  8. del-node :从集群中删除节点
  9. set-timeout :设置集群节点间心跳连接的超时时间
  10. call :在集群全部节点上执行命令
  11. import :将外部redis数据导入集群

redis-trib.rb主要有两个类: ClusterNode 和 RedisTrib 。 ClusterNode 保存了每个节点的信息, RedisTrib 则是redis-trib.rb各个功能的实现

  

  注意:提示最少3个master cluster nodes,前面说是创建6个,但实际操作我只创建了3个节点,所以可以得出我们创建redis集群是最少三个主节点,而且应该是奇数个,so,不要偷懒,再创建三个吧。

  特别注意:这里关键是可选replicas参数,--replicas 2 意思为为每个 master 分配 2 各 slave,replicas表示需要有几个slave。不填写这个参数是可以创建成功的,这样是三个master 。关于replicas参数后面再介绍吧

  

  

首先,--replicas 1   1其实代表的是一个比例,就是主节点数/从节点数的比例。那么想一想,在创建集群的时候,哪些节点是主节点呢?哪些节点是从节点呢?答案是将按照命令中IP:PORT的顺序,先是3个主节点,然后是3个从节点。

其次,注意到图中slot的概念。slot对于Redis集群而言,就是一个存放数据的地方,就是一个槽。对于每一个Master而言,会存在一个slot的范围,而Slave则没有。在Redis集群中,依然是Master可以读、写,而Slave只读。数据的写入,实际上是分布的存储在slot中,这和以前1.X的主从模式是不一样的(主从模式下Master/Slave数据存储是完全一致的),因为Redis集群中3台Master的数据存储并不一样。这个将在后续的随笔中验证。


# windows搭建redis集群  # linux  # redis集群搭建  # redis4.0  # 集群搭建  # redis 哨兵集群搭建的实现  # redis复制集群搭建的实现  # Redis分片集群存储的搭建到使用  # redis集群搭建过程(非常详细  # 适合新手)  # docker实现redis集群搭建的方法步骤  # 详解Redis集群搭建的三种方式  # Redis5之后版本的高可用集群搭建的实现  # docker redis5.0 cluster集群搭建的实现  # Redis集群搭建全记录  # Redis集群搭建(主从模式、哨兵模式、集群模式)  # 自己的  # 一台  # 再把  # 机上  # 的是  # 数据存储  # 会有  # 出了  # 目录下  # 将在  # 我只  # 则是  # 是从  # 要想  # 注意到  # 很简单  # 可以看到  # 有几个  # 可选  # 升级到 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: html如何与html链接_实现多个HTML页面互相链接【互相】  Linux后台任务运行方法_nohup与&使用技巧【技巧】  Laravel怎么实现软删除SoftDeletes_Laravel模型回收站功能与数据恢复【步骤】  Laravel如何实现API资源集合?(Resource Collection教程)  如何在腾讯云服务器快速搭建个人网站?  Laravel如何自定义分页视图?(Pagination示例)  laravel怎么用DB facade执行原生SQL查询_laravel DB facade原生SQL执行方法  JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)  佛山企业网站制作公司有哪些,沟通100网上服务官网?  php做exe能调用系统命令吗_执行cmd指令实现方式【详解】  如何在云虚拟主机上快速搭建个人网站?  胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?  敲碗10年!Mac系列传将迎来「触控与联网」双革新  php485函数参数是什么意思_php485各参数详细说明【介绍】  高端网站建设与定制开发一站式解决方案 中企动力  如何构建满足综合性能需求的优质建站方案?  ,交易猫的商品怎么发布到网站上去?  Laravel如何使用Laravel Vite编译前端_Laravel10以上版本前端静态资源管理【教程】  百度输入法ai面板怎么关 百度输入法ai面板隐藏技巧  在centOS 7安装mysql 5.7的详细教程  实例解析angularjs的filter过滤器  html5源代码发行怎么设置权限_访问权限控制方法与实践【指南】  简历在线制作网站免费版,如何创建个人简历?  ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】  如何快速生成橙子建站落地页链接?  如何在IIS中配置站点IP、端口及主机头?  黑客入侵网站服务器的常见手法有哪些?  如何快速查询网站的真实建站时间?  IOS倒计时设置UIButton标题title的抖动问题  Laravel如何连接多个数据库_Laravel多数据库连接配置与切换教程  如何安全更换建站之星模板并保留数据?  使用豆包 AI 辅助进行简单网页 HTML 结构设计  Laravel Telescope怎么调试_使用Laravel Telescope进行应用监控与调试  EditPlus中的正则表达式 实战(1)  Bootstrap CSS布局之列表  Gemini手机端怎么发图片_Gemini手机端发图方法【步骤】  软银砸40亿美元收购DigitalBridge 强化AI资料中心布局  如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?  大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?  高端智能建站公司优选:品牌定制与SEO优化一站式服务  简单实现Android文件上传  米侠浏览器网页图片不显示怎么办 米侠图片加载修复  关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)  Laravel怎么使用Intervention Image库处理图片上传和缩放  大型企业网站制作流程,做网站需要注册公司吗?  Laravel PHP版本要求一览_Laravel各版本环境要求对照  打造顶配客厅影院,这份100寸电视推荐名单请查收  如何用虚拟主机快速搭建网站?详细步骤解析  lovemo网页版地址 lovemo官网手机登录  Laravel如何集成Inertia.js与Vue/React?(安装配置)