一 、所需软件:Redis、Ruby语言运行环境、Redis的Ruby驱动redis-xxxx.gem、创建Redis集群的工具redis-trib.rb

二 、安装配置redis 

redis下载地址详见上一节Redis安装部分

集群规划有三个节点的集群,每个节点有一主一备。

把 redis 解压后,再复制出 5 份,配置 三主三从集群。 由于 redis 默认端口号为 6379,那么其它5份的端口可以为6380,6381,6382,6383,6384。 并且把目录使用端口号命名

打开目录6379下有一个文件 redis.windows.conf,修改里面的端口号,以及集群支持配置。

修改其他配置支持集群
cluster-enabled yes
cluster-config-file nodes-6379.conf
cluster-node-timeout 15000
appendonly yes

槽是否全覆盖:cluster-require-full-coverage no。默认是yes,只要有结点宕机导致16384个槽没全被覆盖,整个集群就全部停止服务,所以一定要改为no

如果cluster-enabled 不为yes, 那么在使用JedisCluster集群代码获取的时候,会报错。
cluster-node-timeout 调整为  15000,那么在创建集群的时候,不会超时。
cluster-config-file nodes-6379.conf 是为该节点的配置信息,这里使用 nodes-端口.conf命名方法。服务启动后会在目录生成该文件。

编写一个 bat 来启动 redis,在每个节点目录下建立 start.bat,内容如下:
title redis-6380
redis-server.exe redis.windows.conf

做成windows服务

redis-server --service-install redis.windows.conf --service-name redis6379

三 、安装Ruby

redis的集群使用  ruby脚本编写,所以系统需要有 Ruby 环境 ,下载地址 https://dl.bintray.com/oneclick/rubyinstaller/rubyinstaller-2.2.6-x64.exe

安装时3个选项都勾选。

四 、安装Redis的Ruby驱动redis-xxxx.gem

下载地址 https://rubygems.org/pages/download, 下载后解压,当前目录切换到解压目录中,如 D:\Program Files\redis\rubygems-2.6.12 然后在命令行执行  ruby setup.rb。

-------------------------------------------------------------------------------------

安装过程中出现错误提示信息:“cannot load such file -- rubygems.rb”

有可能是因为中文路径(或者其他字符路径)导致的。请卸载ruby之后,然后在英文路径下,重新安装ruby

-------------------------------------------------------------------------------------

然后GEM 安装 Redis :切换到redis安装目录,需要在命令行中,执行 gem install redis

注意:如果此处服务器无法访问外网,这里需要手动更新redis依赖项,方法如下:

打开 https://gems.ruby-china.org/ 网站,在搜索栏中输入 Redis,找到对应版本redis.gem,下载。

将下载的文件拷贝到服务器redis目录下,执行本地安装命令:gem install redis-3.2.1.gem --local ,完成安装

五 、安装集群脚本redis-trib

下载地址  https://raw.githubusercontent.com/antirez/redis/unstable/src/redis-trib.rb

打开该链接如果没有下载,而是打开一个页面,那么将该页面保存为redis-trib.rb,建议保存到一个Redis的目录下,例如放到6379目录下。

集群的命令为

redis-trib.rb create --replicas 1 127.0.0.1:6379 127.0.0.1:6380 127.0.0.1:6381 127.0.0.1:6382 127.0.0.1:6383 127.0.0.1:6384

--replicas 1 表示每个主数据库拥有从数据库个数为1。master节点不能少于3个,所以我们用了6个redis

六、 启动每个节点并且执行集群构建脚本

把每个节点下的 start.bat双击启动, 在切换到redis目录在命令行中执行   redis-trib.rb create --replicas 1 127.0.0.1:6379 127.0.0.1:6380 127.0.0.1:6381 127.0.0.1:6382 127.0.0.1:6383 127.0.0.1:6384

备注:有朋友反应上面的语句执行不成功。可以在前面加上ruby再运行。

  ruby redis-trib.rb create --replicas 1 127.0.0.1:6379 127.0.0.1:6380 127.0.0.1:6381 127.0.0.1:6382 127.0.0.1:6383 127.0.0.1:6384

在出现 Can I set the above configuration? (type 'yes' to accept):   请确定并输入 yes 。成功后的结果如下:

七、测试

使用Redis客户端Redis-cli.exe来查看数据记录数,以及集群相关信息

命令 redis-cli –c –h ”地址” –p "端口号" ;  c 表示集群

输入dbsize查询 记录总数

输入cluster info可以从客户端的查看集群的信息

最新文章

  1. switch与ifelse的效率问题
  2. 获取openid 的步骤
  3. 【python游戏编程之旅】第五篇---嗷大喵爱吃鱼小游戏开发实例
  4. xfce4桌面自动整理脚本
  5. 简单ssh框架整合
  6. Spark Job Scheduling
  7. Linq中Take、TakeWhile、Skip、SkipWhile的比较(转)
  8. Error:Failed to open zip file. Gradle's dependency cache may be corrupt (this sometimes occurs after a network connection timeout.)
  9. bzoj4819 [Sdoi2017]新生舞会
  10. 机器学习技法:06 Support Vector Regression
  11. JavaWeb项目架构之NFS文件服务器
  12. PS 滤镜——Skewing
  13. 前端笔记之JavaScript(七)深入函数&DOM那点事
  14. 3proxy使用方法
  15. Sequential Minimal Optimization (SMO) 算法
  16. 广播消费:允许一个 Group ID 所标识的所有 Consumer 都会各自消费某条消息一次。
  17. windows版mysql配置--my.ini
  18. 转 springboot 监控点 简介
  19. ubuntu安装wine
  20. barba 页面渲染

热门文章

  1. paramiko 简单的使用
  2. 转载-30分钟搞定后台登录界面(103个后台PSD源文件、素材网站)
  3. Appium+python的单元测试框架unittest(1)(转)
  4. Unity — — UGUI之背包物品拖放
  5. Unity 自定义编辑器窗口 画线
  6. SQL知识点脑图(一张图总结SQL)
  7. 使用maven&&make-distribution.sh编译打包spark源码
  8. Swing的概述
  9. jar包、war包
  10. 你也可以手绘二维码(二)纠错码字算法:数论基础及伽罗瓦域GF(2^8)