环境

RHLinux-6.4-64-EN, 红帽6.4 64位,英文正式公布版。

Redis3.0.0

  • redis2.x版本号还不支持集群,3.0版本号将会支持,如今3.0版本号还在开发中,如今是beta-3版本号(截止2014-5-8),但功能是可用的。
  • 下载Redis3.0.0 beta-3版本号,点击这里下载。
  • Redis3的安装能够參照之前的单机安装指南操作。

创建Redis集群实例

  • 创建集群节点的目录,先创建cluster-test目录,再以port为名称创建子目录。这里我们要创建6个Redis实例,3个作为master,3个作为slave。
  1. 1
  2. 2
  3. 3
  1. mkdir cluster-test
  2. cd cluster-test
  3. mkdir 7000 7001 7002 7003 7004 7005
  • 在每一个目录以下创建创建Redis配置文件,注意依据不同实例的port号改动以下的配置文件,nodes.conf文件为Redis实例启动时自己主动生成。
  1. 1
  2. 2
  3. 3
  4. 4
  5. 5
  1. port 7000
  2. cluster-enabled yes
  3. cluster-config-file nodes.conf
  4. cluster-node-timeout 5000
  5. appendonly yes
  • 开6个terminal窗体,分别启动这6个Redis实例。
  1. 1
  2. 2
  1. cd 7000
  2. ../redis-server ./redis.conf
  • 当成功启动后,能看到每一个terminal出现以下的字样,是由于node.conf文件不存在,所以给每一个实例分配了一个新的ID。
  1. 1
  1. [82462] 26 Nov 11:56:55.329 * No cluster configuration found, I'm 97a3a64667477371c4479320d683e4c8db5858b1

创建集群

  • 如今Redis的6个实例都已经启动了,如今来開始创建集群。创建集群用到了一个ruby文件,放在redis3文件夹的src子文件夹下,找到后运行下面命令。这里的-replicas
    1
    表示每一个master配备1个slave,后面的參数就是6个实例的ip加port,以空格隔开。
  1. 1
  2. 2
  3. 3
  1. cd redis-3.0.0-beta3/src
  2. ./redis-trib.rb create --replicas 1 127.0.0.1:7000 127.0.0.1:7001 \
  3. 127.0.0.1:7002 127.0.0.1:7003 127.0.0.1:7004 127.0.0.1:7005
  • 运行命令后会提示你是否接受提示的配置信息,默认的是前3台作为master机器,后3台作为slave机器,输入yes,出现最后的信息表示集群已经创建好了。
  1. 1
  2. 2
  3. 3
  4. 4
  5. 5
  6. 6
  7. 7
  8. 8
  9. 9
  10. 10
  11. 11
  12. 12
  13. 13
  14. 14
  15. 15
  16. 16
  17. 17
  18. 18
  19. 19
  20. 20
  21. 21
  22. 22
  23. 23
  24. 24
  25. 25
  26. 26
  27. 27
  28. 28
  29. 29
  30. 30
  31. 31
  32. 32
  33. 33
  34. 34
  35. 35
  36. 36
  37. 37
  38. 38
  39. 39
  40. 40
  41. 41
  42. 42
  1. Creating cluster
  2. Connecting to node 127.0.0.1:7000: OK
  3. Connecting to node 127.0.0.1:7001: OK
  4. Connecting to node 127.0.0.1:7002: OK
  5. Connecting to node 127.0.0.1:7003: OK
  6. Connecting to node 127.0.0.1:7004: OK
  7. Connecting to node 127.0.0.1:7005: OK >>>
  8. Performing hash slots allocation on 6 nodes...
  9. Using 3 masters: 127.0.0.1:7000 127.0.0.1:7001 127.0.0.1:7002
  10. 127.0.0.1:7000 replica #1 is 127.0.0.1:7003
  11. 127.0.0.1:7001 replica #1 is 127.0.0.1:7004
  12. 127.0.0.1:7002 replica #1 is 127.0.0.1:7005
  13. M: 9991306f0e50640a5684f1958fd754b38fa034c9 127.0.0.1:7000 slots:0-5460 (5461 slots) master
  14. M: e68e52cee0550f558b03b342f2f0354d2b8a083b 127.0.0.1:7001 slots:5461-10921 (5461 slots) master
  15. M: 393c6df5eb4b4cec323f0e4ca961c8b256e3460a 127.0.0.1:7002 slots:10922-16383 (5462 slots) master
  16. S: 48b728dbcedff6bf056231eb44990b7d1c35c3e0 127.0.0.1:7003
  17. S: 345ede084ac784a5c030a0387f8aaa9edfc59af3 127.0.0.1:7004
  18. S: 3375be2ccc321932e8853234ffa87ee9fde973ff 127.0.0.1:7005
  19. Can I set the above configuration? (type 'yes' to accept): yes
  20. Nodes configuration updated >>>
  21. Sending CLUSTER MEET messages to join the cluster Waiting for the cluster to join... >>>
  22. Performing Cluster Check (using node 127.0.0.1:7000)
  23. M: ebbb890e899244e4a2a6303826a29543ebf9885d 127.0.0.1:7000
  24. slots:0-5460 (5461 slots) master
  25. M: ebbb890e899244e4a2a6303826a29543ebf9885d 127.0.0.1:7001
  26. slots:5461-10922 (5462 slots) master
  27. M: 73c22198cd1d0782ec24e3c9b03378030891c9a3 127.0.0.1:7002
  28. slots:10923-16383 (5461 slots) master
  29. M: c785d85b95d7bdc28ec90384ab8a5885b289542c 127.0.0.1:7003
  30. slots: (0 slots) master
  31. replicates b949ea2d9c822ff069521a354b4ed48855ac6203
  32. M: 570c472fe553ba3c9d0fb3ba16fcdb8579b4fc86 127.0.0.1:7004
  33. slots: (0 slots) master
  34. replicates ebbb890e899244e4a2a6303826a29543ebf9885d
  35. M: f86667ec42cff41a5666162a912713173f5306d7 127.0.0.1:7005
  36. slots: (0 slots) master
  37. replicates 73c22198cd1d0782ec24e3c9b03378030891c9a3
  38. [OK] All nodes agree about slots configuration.
  39. >>> Check for open slots...
  40. >>> Check slots coverage...
  41. [OK] All 16384 slots covered.

PS: 安装过程还发现RedHat系统上没有安装ruby,须要先安装ruby,并且公司机器还不能上网下载安装,仅仅能通过离线的方式安装ruby,这里有离线安装的文档能够參考一下:https://rvm.io/rvm/offline

验证

能够使用Redis3.0的redis-cliclient进行验证,须要加上-c參数,表示集群的意思。

  1. 1
  2. 2
  3. 3
  4. 4
  5. 5
  6. 6
  7. 7
  8. 8
  9. 9
  10. 10
  11. 11
  12. 12
  13. 13
  1. $ redis-cli -c -p 7000
  2. redis 127.0.0.1:7000> set foo bar
  3. -> Redirected to slot [12182] located at 127.0.0.1:7002
  4. OK
  5. redis 127.0.0.1:7002> set hello world
  6. -> Redirected to slot [866] located at 127.0.0.1:7000
  7. OK
  8. redis 127.0.0.1:7000> get foo
  9. -> Redirected to slot [12182] located at 127.0.0.1:7002
  10. "bar"
  11. redis 127.0.0.1:7000> get hello
  12. -> Redirected to slot [866] located at 127.0.0.1:7000
  13. "world"

很多其它的资料能够參考这里:http://redis.io/topics/cluster-tutorial

Redis集群环境安装指南的更多相关文章

  1. Redis 集群环境添加节点失败问题

    最近在给公司网管系统Redis集群环境添加节点时候遇到一个问题,提示新增的Node不为空: [root@node00 src]# ./redis-trib.rb add-node --slave -- ...

  2. redis集群环境的搭建和错误分析

    redis集群环境的搭建和错误分析 redis集群时,出现的几个异常问题 09 redis集群的搭建 以及遇到的问题

  3. 带你自行搭建虚拟机和Redis集群环境,值得收藏!

    前言: 我们看到分析 Redis 使用或原理的文章不少,但是完整搭建一套独立的 redis 集群环境的介绍,并不是很多或者说还不够详细. 那么,本文会手把手带着大家搭建一套 Redis 集群环境,Re ...

  4. SpringBoot系列教程之Redis集群环境配置

    之前介绍的几篇redis的博文都是基于单机的redis基础上进行演示说明的,然而在实际的生产环境中,使用redis集群的可能性应该是大于单机版的redis的,那么集群的redis如何操作呢?它的配置和 ...

  5. Redis集群环境之linux搭建多机版---已完结,跟着一步一步来你就可以集群成功

    上一篇踩着各种坑写了Redis集群环境之linux搭建单机版,这一篇准备就多机版集群进行搭建,主要目的一来是在上一篇的基础上进行精华提粹总结,二来是把单机版与多机版的区别进行记录. 首先软硬件环境: ...

  6. Redis集群环境搭建实践

    0 Redis集群简介 Redis集群(Redis Cluster)是Redis提供的分布式数据库方案,通过分片(sharding)来进行数据共享,并提供复制和故障转移功能.相比于主从复制.哨兵模式, ...

  7. centos7 快速搭建redis集群环境

    本文主要是记录一下快速搭建redis集群环境的方式. 环境简介:centos 7  + redis-3.2.4 本次用两个服务6个节点来搭建:192.168.116.120  和  192.168.1 ...

  8. redis集群环境配置

    为什么需要集群 redis是一个开源的 key->value 高速存储系统,但是由于redis单线程运行,在系统中,只能利用单核的性能 当redis的调用越来越频繁时,可能会出现redis过于繁 ...

  9. redis 集群环境搭建-redis集群管理

    集群架构 (1)所有的redis节点彼此互联(PING-PONG机制),内部使用二进制协议优化传输速度和带宽. (2)节点的fail是通过集群中超过半数的节点检测失效时才生效. (3)客户端与redi ...

随机推荐

  1. uva 11396Claw Decomposotion(二分图判定)

     题目大意:给出一个简单无向图,每一个点的度为3.推断是否能将此图分解成若干爪的形式.使得每条边都仅仅出如今唯一的爪中. (点能够多次出如今爪中) 这道题实质上就是问这个图是否为二分图,dfs判定 ...

  2. zoj 3288 Domination (可能dp)

    ///dp[i][j][k]代表i行j列件,并把一k的概率 ///dp[i][j][k]一种常见的方法有四种传输 ///1:dp[i-1][j][k-1] 可能 (n-(i-1))*j/(n*m-(k ...

  3. 重新想象 Windows 8 Store Apps (23) - 文件系统: 文本的读写, 二进制的读写, 流的读写, 最近访问列表和未来访问列表

    原文:重新想象 Windows 8 Store Apps (23) - 文件系统: 文本的读写, 二进制的读写, 流的读写, 最近访问列表和未来访问列表 [源码下载] 重新想象 Windows 8 S ...

  4. 设单链表中存放n个字符,试设计一个算法,使用栈推断该字符串是否中心对称

    转载请注明出处:http://blog.csdn.net/u012860063 问题:设单链表中存放n个字符.试设计一个算法,使用栈推断该字符串是否中心对称,如xyzzyx即为中心对称字符串. 代码例 ...

  5. js你真的了解offsetWidth吗

    offsetWidth是什么? 答:它可以获取物体宽度的数值 那么就只是这样吗! html部分 <div id="div1"></div> <styl ...

  6. Android开发之Handler和Looper的关系

              关于Handler的总结. Message:消息,当中包括了消息ID,消息处理对象以及处理的数据等,由MessageQueue统一列队,终由Handler处理. Handler:处 ...

  7. cocos2dx三种定时器使用

         cocos2dx三种定时器的使用以及停止schedule.scheduleUpdate.scheduleOnce 今天白白跟大家分享一下cocos2dx中定时器的用法. 首先,什么是定时 ...

  8. async And await异步编程活用基础

    原文:async And await异步编程活用基础 好久没写博客了,时隔5个月,奉上一篇精心准备的文章,希望大家能有所收获,对async 和 await 的理解有更深一层的理解. async 和 a ...

  9. 深入浅出JMS(一)——JMS简要

    假设手机只能实时通话.没有邮件和短信功能发生?一个电话回来.只是没有足够的时间去连接.然后传递这款手机的信息肯定是不接受. 么不能先将信息存下来.当用户须要查看信息的时候再去获得信息呢?伴随着这个疑惑 ...

  10. 发现SQL Server惊天大秘密!!

    原文:发现SQL Server惊天大秘密!! --set statistics xml onCREATE TABLE T_TEST(ID INT IDENTITY PRIMARY KEY,Create ...