本文主要是在centos7上安装和配置redis集群实战 
参考: 
http://hot66hot.iteye.com/blog/2050676 
集群教程: 
http://redisdoc.com/topic/cluster-tutorial.html#id2

1 安装准备

1.1 下载redis3.0版本

到redis官网redis.io或者redis中文官网www.redis.cn上(http://www.redis.cn/download.html)去下载最新的版本,我下载的是redis3.0.3版本,下载后,解压,make后,在src下已经生成redis-cli,redis-server等可执行文件 
将redis-cli,redis-server,redis-trib.rb cp一个到/usr/bin下或者你目录的bin下

1.2 redis 集群安装

  1. 安装ruby 
    由于redis-trib.rb是用ruby写的,所以需要安装ruby,在联网的方式上,使用

    • yum install -y ruby
    • 安装完成后,使用ruby --version查看ruby是否正确安装,当前我安装的版本是(ruby 2.0.0p598)
  2. 安装rubygem 
  3. 安装gem-redis 

2 启动集群

  • 启动redis实例

在这里用最简单的例子,启动3个redis实例,端口分别为7000,7002,7003,修改对应配置,并且进行启动 
修改配置主要包括:

- 端口:修改对应成7000,7001,7002
- 对应的log,pid,data目录
- 集群配置:
cluster-enabled yes
cluster-config-file nodes-700x.conf #集群在启动时会自动生成
cluster-node-timeout 5000
  • 启动redis集群

    ./redis-trib.rb create 127.0.0.1:7000 127.0.0.1:7001 127.0.0.1:7002

    启动集群时,会有如下一些提示:

    Creating cluster 
    Connecting to node 127.0.0.1:7000: OK 
    Connecting to node 127.0.0.1:7001: OK 
    Connecting to node 127.0.0.1:7002: OK 
    Performing hash slots allocation on 3 nodes... 
    Using 3 masters: 
    127.0.0.1:7000 
    127.0.0.1:7001 
    127.0.0.1:7002 
    M: 36fce4bf6c829797c433c08b045a8c482e07fbc1 127.0.0.1:7000 
    slots:0-5460 (5461 slots) master 
    M: 7e46925ca9781a403facf450aa0b4b8149ad9c27 127.0.0.1:7001 
    slots:5461-10922 (5462 slots) master 
    M: e89c01d7cc2a83f072f66d0c2fb1f5cd92c66888 127.0.0.1:7002 
    slots:10923-16383 (5461 slots) master 
    Can I set the above configuration? (type 'yes' to accept): yes 
    Nodes configuration updated 
    Assign a different config epoch to each node 
    Sending CLUSTER MEET messages to join the cluster 
    Waiting for the cluster to join.. 
    Performing Cluster Check (using node 127.0.0.1:7000) 
    M: 36fce4bf6c829797c433c08b045a8c482e07fbc1 127.0.0.1:7000 
    slots:0-5460 (5461 slots) master 
    M: 7e46925ca9781a403facf450aa0b4b8149ad9c27 127.0.0.1:7001 
    slots:5461-10922 (5462 slots) master 
    M: e89c01d7cc2a83f072f66d0c2fb1f5cd92c66888 127.0.0.1:7002 
    slots:10923-16383 (5461 slots) master 
    [OK] All nodes agree about slots configuration. 
    Check for open slots... 
    Check slots coverage... 
    [OK] All 16384 slots covered.

  • 使用客户端连接集群 
    使用redis-cli客户端连接集群

    [root@bogon bin]# ./redis-cli -c -p 7001 
    127.0.0.1:7001> set a b 
    -> Redirected to slot [15495] located at 127.0.0.1:7002 
    OK 
    127.0.0.1:7002> set c d 
    -> Redirected to slot [7365] located at 127.0.0.1:7001 
    OK 
    其中redis-cli -c标志表示连接的是一个集群,通过set方式可以看出,会将key进行crc16后hash分片到不同的redis实例上,redis-cli会通过跟redis集群进行交互,把key基于hash分片,把请求自动转到不同的实例上

 

3 安装时遇到的其它问题

3.1 执行./redis-trib.rb时提示 json/pcre not fount

这个表示redis-trib.rb依赖的json_pure在机器中不存在:

- 到官网http://rpmfind.net/linux/RPM/opensuse/13.1/x86_64/rubygem-json_pure-1.8.0-2.1.2.x86_64.html,下载对应的rpm包
- json_pure的rpm包需要依赖其它rpm包,如下,如果安装json_pure失败,需要根据提示,下载依赖的rpm包并进行安装
/usr/bin/ruby
rpmlib(CompressedFileNames) <= 3.0.4-1
rpmlib(PayloadFilesHavePrefix) >= 4.0-1
ruby(abi) >= 2.0.0
rpmlib(PayloadIsLzma) >= 4.4.6-1

redis3.0 集群实战1 -- 安装和配置的更多相关文章

  1. redis3.0 集群实战3 - java编程实战

    本文主要描述使用jedis进行redis-cluster操作   jedis jedis是redis官方推荐使用的java redis客户端,github地址为,https://github.com/ ...

  2. redis3.0 集群实战2 - 集群功能实战

    1 集群基本操作   1.1 查看当前集群状态 使用redis-trib.rb check功能查看对应的节点的状态: [root@bogon bin]# ./redis-trib.rb check 1 ...

  3. redis3.0 集群在windows上的配置(转)

    1. 安装Redis版本:win-3.0.501https://github.com/MSOpenTech/redis/releases页面有,我下载的是zip版本的:Redis-x64-3.0.50 ...

  4. Dubbo入门到精通学习笔记(十八):使用Redis3.0集群实现Tomcat集群的Session共享

    文章目录 1.单节点访问http://192.168.1.61:8082/pay-web-boss/: 2.增加多一个消费者节点:192.168.1.62,以同样的方式部署pay-web-boss工程 ...

  5. redis3.0集群搭建

    生产环境中准备使用redis3.0集群了,花了一天时间研究了一下,下面记录一下集群搭建的过程. 服务器规划: 192.168.116.129    7000,7003 192.168.116.130 ...

  6. redis3.0集群部署和测试

    redis3.0集群部署和测试 环境介绍 两台Centos7的虚拟机模拟6个节点,A台3个master节点,B台3个slave节点A地址:172.16.81.140B地址:172.16.81.141r ...

  7. Redis3.0集群方案分析

    在Redis3.0集群出来之前,大家都对作者antirez寄予厚望,因为Redis从来没有让我们失望过.现在Redis3.0集群出来了,网上出了很多评论文章,都说他的功能多么强大,包括下面这张图是彻底 ...

  8. 理解 OpenStack Swift (1):OpenStack + 三节点Swift 集群+ HAProxy + UCARP 安装和配置

    本系列文章着重学习和研究OpenStack Swift,包括环境搭建.原理.架构.监控和性能等. (1)OpenStack + 三节点Swift 集群+ HAProxy + UCARP 安装和配置 ( ...

  9. redis3.0.5在linux上安装与配置

    redis3.0.5在linux上安装与配置 rhel6/ubuntu14 1 下载 # wget http://download.redis.io/releases/redis-3.0.5.tar. ...

随机推荐

  1. SQL语句 - 数据操作

    表中数据的变化牵一发而动全身,会同时导致到索引中数据的变化.因此如果查询语句不需要索引,就应该删除无用的索引以提高效率. 一.INSERT语句 1.基本插入语句 insert用于向表中输入数据,其具体 ...

  2. css3实现进度条的模拟

    两种进度条动画的实现: 1.css3,但IE9-不支持. 2.js动画,兼容性好,但没有css3实现的顺畅 Demo: <html>    <head>        < ...

  3. CLR via C#深解笔记六 - 泛型

    面向对象编程一个好处就是“代码重用”,极大提高了开发效率.如是,可以派生出一个类,让它继承基类的所有能力,派生类只需要重写虚方法,或添加一些新的方法,就可以定制派生类的行为,使之满足开发人员的需求. ...

  4. python网站收集

    1.python核心编程 习题答案    http://www.cnblogs.com/balian/category/279009.html 2.编程语言入门经典100例(python版)  htt ...

  5. 【PRML读书笔记-Chapter1-Introduction】1.4 The Curse of Dimensionality

    维数灾难 给定如下分类问题: 其中x6和x7表示横轴和竖轴(即两个measurements),怎么分? 方法一(simple): 把整个图分成:16个格,当给定一个新的点的时候,就数他所在的格子中,哪 ...

  6. udp穿透简单讲解和实现(Java)

    在上一小节中了解到了通过浏览器自带的Webrtc功能来实现P2P视频聊天.在HTML5还没有普及和制定Webrtc标准的前提下,如果要在手机里进行视频实时对话等包括其他功能的话,还是要自己实现,还比较 ...

  7. ionic 添加地图定位功能

    由于项目需求,需要一个定位功能,通过google或百度,搜到一个cordova-plugin-geolocation的插件,在ios上可以用,但是在android就呵呵了,原因就不说了,大家都知道.所 ...

  8. WCF小白初试 错误之一:“有零个应用程序终结点”的解决办法

    遇到这类问题 应该是配置文件出现了问题 解决办法是将配置文件中的<service name="命名空间+类名">就可以解决

  9. Tips6:用[HideInInspector]在Inspector中隐藏变量

    你曾想要把某些公有变量在Inspetor面板中隐藏起来吗,这样很简单就能做到. 让我们来看以下代码: using UnityEngine; public class HidingScript : Mo ...

  10. 移动端 ios 长按复制兼容方案

    移动端页面,需要复制一段文字码. 在ios中,长按文字区域,默认选中的范围,超出了我长按的文字区域, 把上面的图片和下面的另一个div的文字也给我包含进来了,并不是我想要的! 举个例子: 如下图: 1 ...