• 下载
 
[root@localhost ~]# cd /usr/local/src/
[root@localhost src]# wget http://download.redis.io/releases/redis-3.2.6.tar.gz
  • 编译安装
 
[root@localhost src]# tar zxvf redis-3.2.6.tar.gz -C /usr/local/soft/
[root@localhost src]# cd /usr/local/soft/
[root@localhost soft]# cd redis-3.2.6/
[root@localhost redis-3.2.6]# make && make install
[root@localhost redis-3.2.6]# cd /usr/local/soft/
[root@localhost soft]# mkdir redis_cluster
[root@localhost soft]# cd redis_cluster/
[root@localhost redis_cluster]# mkdir 7000 7001 7002
[root@localhost redis_cluster]# cp /usr/local/soft/redis-3.2.6/redis.conf /usr/local/soft/redis_cluster/7000
[root@localhost redis_cluster]# cp /usr/local/soft/redis-3.2.6/redis.conf /usr/local/soft/redis_cluster/7001
[root@localhost redis_cluster]# cp /usr/local/soft/redis-3.2.6/redis.conf /usr/local/soft/redis_cluster/7002
  • 修改配置文件
 
daemonize    yes                          //redis后台运行

pidfile  /var/run/redis_7000.pid          //pidfile文件对应7000,7002,7003

port  7000                                //端口7000,7002,7003

cluster-enabled  yes                      //开启集群  把注释#去掉

cluster-config-file  nodes_7000.conf      //集群的配置  配置文件首次启动自动生成 7000,7001,7002

cluster-node-timeout  5000                //请求超时  设置5秒够了
appendonly  yes
bind 真实ip地址
  • 关闭安全模式
 
redis-cli -p 7000 CONFIG SET protected-mode no
 
  • 启动redis
 
[root@localhost redis_cluster]# redis-server /usr/local/soft/redis_cluster/7000/redis.conf
[root@localhost redis_cluster]# redis-server /usr/local/soft/redis_cluster/7001/redis.conf
[root@localhost redis_cluster]# redis-server /usr/local/soft/redis_cluster/7002/redis.conf
[root@localhost redis_cluster]# ps -ef | grep redis
root       5842      1  0 19:41 ?        00:00:00 redis-server 127.0.0.1:7000 [cluster]                     
root       5862      1  0 19:42 ?        00:00:00 redis-server 127.0.0.1:7001 [cluster]                     
root       5866      1  0 19:42 ?        00:00:00 redis-server 127.0.0.1:7002 [cluster]                     
root       5871   2583  0 19:42 pts/0    00:00:00 grep redis
[root@localhost redis_cluster]# netstat -tnpl | grep redis
tcp        0      0 127.0.0.1:17000             0.0.0.0:*                   LISTEN      5842/redis-server 1
tcp        0      0 127.0.0.1:17001             0.0.0.0:*                   LISTEN      5862/redis-server 1
tcp        0      0 127.0.0.1:17002             0.0.0.0:*                   LISTEN      5866/redis-server 1
tcp        0      0 127.0.0.1:7000              0.0.0.0:*                   LISTEN      5842/redis-server 1
tcp        0      0 127.0.0.1:7001              0.0.0.0:*                   LISTEN      5862/redis-server 1
tcp        0      0 127.0.0.1:7002              0.0.0.0:*                   LISTEN      5866/redis-server 1
  • 创建集群
 
[root@localhost redis_cluster]# cd /usr/local/soft/redis-3.2.6/src/
[root@localhost src]# ./redis-trib.rb
/usr/bin/env: ruby: No such file or directory
  • 如果没有安装ruby,则安装
 
[root@localhost src]# yum -y install ruby ruby-devel rubygems rpm-build
  • 安装redis接口
 
[root@localhost src]# gem install redis
  • 查看ruby是否安装成功
 
[root@localhost src]# ./redis-trib.rb
Usage: redis-trib <command> <options> <arguments ...>
 
  rebalance       host:port
                  --threshold <arg>
                  --simulate
                  --weight <arg>
                  --timeout <arg>
                  --auto-weights
                  --pipeline <arg>
                  --use-empty-masters
  info            host:port
  check           host:port
  fix             host:port
                  --timeout <arg>
  add-node        new_host:new_port existing_host:existing_port
                  --master-id <arg>
                  --slave
  import          host:port
                  --replace
                  --copy
                  --from <arg>
  reshard         host:port
                  --to <arg>
                  --from <arg>
                  --yes
                  --timeout <arg>
                  --slots <arg>
                  --pipeline <arg>
  help            (show this help)
  call            host:port command arg arg .. arg
  set-timeout     host:port milliseconds
  del-node        host:port node_id
  create          host1:port1 ... hostN:portN
                  --replicas <arg>
 
For check, fix, reshard, del-node, set-timeout you can specify the host and port of any working node in the cluster.
  • 创建集群
 
[root@localhost src]# ./redis-trib.rb create --replicas 1 127.0.0.1:7000 127.0.0.1:7001 127.0.0.1:7002
>>> Creating cluster
*** ERROR: Invalid configuration for cluster creation.
*** Redis Cluster requires at least 3 master nodes.
*** This is not possible with 3 nodes and 1 replicas per node.
*** At least 6 nodes are required.
  • 新开一台机子, 配置如上, 端口号为 7003 7004 7005
  • 开放端口号 7000 7001 7002 7003 7004 7005 17000 17001 17002 17003 17004 17005
  • 再次创建集群
 
[root@localhost redis_cluster]# /usr/local/soft/redis-3.2.6/src/redis-trib.rb create --replicas 1 192.168.59.128:7000 192.168.59.128:7001 192.168.59.128:7002 192.168.59.129:7003 192.168.59.129:7004 192.168.59.129:7005
>>> Creating cluster
>>> Performing hash slots allocation on 6 nodes...
Using 3 masters:
192.168.59.129:7003
192.168.59.128:7000
192.168.59.129:7004
Adding replica 192.168.59.128:7001 to 192.168.59.129:7003
Adding replica 192.168.59.129:7005 to 192.168.59.128:7000
Adding replica 192.168.59.128:7002 to 192.168.59.129:7004
M: bbf1f1150a661ec3adee9ecb37ab140c03290582 192.168.59.128:7000
   slots:5461-10922 (5462 slots) master
S: 046219f4f154a5a757877cd1dc0f186423942424 192.168.59.128:7001
   replicates ccd1c5d708b1844881c13ac4c6ac467574ff23f7
S: f5e01feb8dd6f085c3b25c35f25753f6b2fa750b 192.168.59.128:7002
   replicates c7af24dcbe0ea6c26aec9965573c82130e98718a
M: ccd1c5d708b1844881c13ac4c6ac467574ff23f7 192.168.59.129:7003
   slots:0-5460 (5461 slots) master
M: c7af24dcbe0ea6c26aec9965573c82130e98718a 192.168.59.129:7004
   slots:10923-16383 (5461 slots) master
S: 0b9385e4fb3a939414891a00585f65c2fa07c29b 192.168.59.129:7005
   replicates bbf1f1150a661ec3adee9ecb37ab140c03290582
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 192.168.59.128:7000)
M: bbf1f1150a661ec3adee9ecb37ab140c03290582 192.168.59.128:7000
   slots:5461-10922 (5462 slots) master
   1 additional replica(s)
S: 046219f4f154a5a757877cd1dc0f186423942424 192.168.59.128:7001
   slots: (0 slots) slave
   replicates ccd1c5d708b1844881c13ac4c6ac467574ff23f7
S: 0b9385e4fb3a939414891a00585f65c2fa07c29b 192.168.59.129:7005
   slots: (0 slots) slave
   replicates bbf1f1150a661ec3adee9ecb37ab140c03290582
M: ccd1c5d708b1844881c13ac4c6ac467574ff23f7 192.168.59.129:7003
   slots:0-5460 (5461 slots) master
   1 additional replica(s)
S: f5e01feb8dd6f085c3b25c35f25753f6b2fa750b 192.168.59.128:7002
   slots: (0 slots) slave
   replicates c7af24dcbe0ea6c26aec9965573c82130e98718a
M: c7af24dcbe0ea6c26aec9965573c82130e98718a 192.168.59.129:7004
   slots:10923-16383 (5461 slots) master
   1 additional replica(s)
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.
  • 下载
 
[root@localhost ~]# cd /usr/local/src/
[root@localhost src]# wget http://download.redis.io/releases/redis-3.2.6.tar.gz
  • 编译安装
 
[root@localhost src]# tar zxvf redis-3.2.6.tar.gz -C /usr/local/soft/
[root@localhost src]# cd /usr/local/soft/
[root@localhost soft]# cd redis-3.2.6/
[root@localhost redis-3.2.6]# make && make install
[root@localhost redis-3.2.6]# cd /usr/local/soft/
[root@localhost soft]# mkdir redis_cluster
[root@localhost soft]# cd redis_cluster/
[root@localhost redis_cluster]# mkdir 7000 7001 7002
[root@localhost redis_cluster]# cp /usr/local/soft/redis-3.2.6/redis.conf /usr/local/soft/redis_cluster/7000
[root@localhost redis_cluster]# cp /usr/local/soft/redis-3.2.6/redis.conf /usr/local/soft/redis_cluster/7001
[root@localhost redis_cluster]# cp /usr/local/soft/redis-3.2.6/redis.conf /usr/local/soft/redis_cluster/7002
  • 修改配置文件
 
daemonize    yes                          //redis后台运行

pidfile  /var/run/redis_7000.pid          //pidfile文件对应7000,7002,7003

port  7000                                //端口7000,7002,7003

cluster-enabled  yes                      //开启集群  把注释#去掉

cluster-config-file  nodes_7000.conf      //集群的配置  配置文件首次启动自动生成 7000,7001,7002

cluster-node-timeout  5000                //请求超时  设置5秒够了
appendonly  yes
bind 真实ip地址
  • 关闭安全模式
 
redis-cli -p 7000 CONFIG SET protected-mode no
 
  • 启动redis
 
[root@localhost redis_cluster]# redis-server /usr/local/soft/redis_cluster/7000/redis.conf
[root@localhost redis_cluster]# redis-server /usr/local/soft/redis_cluster/7001/redis.conf
[root@localhost redis_cluster]# redis-server /usr/local/soft/redis_cluster/7002/redis.conf
[root@localhost redis_cluster]# ps -ef | grep redis
root       5842      1  0 19:41 ?        00:00:00 redis-server 127.0.0.1:7000 [cluster]                     
root       5862      1  0 19:42 ?        00:00:00 redis-server 127.0.0.1:7001 [cluster]                     
root       5866      1  0 19:42 ?        00:00:00 redis-server 127.0.0.1:7002 [cluster]                     
root       5871   2583  0 19:42 pts/0    00:00:00 grep redis
[root@localhost redis_cluster]# netstat -tnpl | grep redis
tcp        0      0 127.0.0.1:17000             0.0.0.0:*                   LISTEN      5842/redis-server 1
tcp        0      0 127.0.0.1:17001             0.0.0.0:*                   LISTEN      5862/redis-server 1
tcp        0      0 127.0.0.1:17002             0.0.0.0:*                   LISTEN      5866/redis-server 1
tcp        0      0 127.0.0.1:7000              0.0.0.0:*                   LISTEN      5842/redis-server 1
tcp        0      0 127.0.0.1:7001              0.0.0.0:*                   LISTEN      5862/redis-server 1
tcp        0      0 127.0.0.1:7002              0.0.0.0:*                   LISTEN      5866/redis-server 1
  • 创建集群
 
[root@localhost redis_cluster]# cd /usr/local/soft/redis-3.2.6/src/
[root@localhost src]# ./redis-trib.rb
/usr/bin/env: ruby: No such file or directory
  • 如果没有安装ruby,则安装
 
[root@localhost src]# yum -y install ruby ruby-devel rubygems rpm-build
  • 安装redis接口
 
[root@localhost src]# gem install redis
  • 查看ruby是否安装成功
 
[root@localhost src]# ./redis-trib.rb
Usage: redis-trib <command> <options> <arguments ...>
 
  rebalance       host:port
                  --threshold <arg>
                  --simulate
                  --weight <arg>
                  --timeout <arg>
                  --auto-weights
                  --pipeline <arg>
                  --use-empty-masters
  info            host:port
  check           host:port
  fix             host:port
                  --timeout <arg>
  add-node        new_host:new_port existing_host:existing_port
                  --master-id <arg>
                  --slave
  import          host:port
                  --replace
                  --copy
                  --from <arg>
  reshard         host:port
                  --to <arg>
                  --from <arg>
                  --yes
                  --timeout <arg>
                  --slots <arg>
                  --pipeline <arg>
  help            (show this help)
  call            host:port command arg arg .. arg
  set-timeout     host:port milliseconds
  del-node        host:port node_id
  create          host1:port1 ... hostN:portN
                  --replicas <arg>
 
For check, fix, reshard, del-node, set-timeout you can specify the host and port of any working node in the cluster.
  • 创建集群
 
[root@localhost src]# ./redis-trib.rb create --replicas 1 127.0.0.1:7000 127.0.0.1:7001 127.0.0.1:7002
>>> Creating cluster
*** ERROR: Invalid configuration for cluster creation.
*** Redis Cluster requires at least 3 master nodes.
*** This is not possible with 3 nodes and 1 replicas per node.
*** At least 6 nodes are required.
  • 新开一台机子, 配置如上, 端口号为 7003 7004 7005
  • 开放端口号 7000 7001 7002 7003 7004 7005 17000 17001 17002 17003 17004 17005
  • 再次创建集群
 
[root@localhost redis_cluster]# /usr/local/soft/redis-3.2.6/src/redis-trib.rb create --replicas 1 192.168.59.128:7000 192.168.59.128:7001 192.168.59.128:7002 192.168.59.129:7003 192.168.59.129:7004 192.168.59.129:7005
>>> Creating cluster
>>> Performing hash slots allocation on 6 nodes...
Using 3 masters:
192.168.59.129:7003
192.168.59.128:7000
192.168.59.129:7004
Adding replica 192.168.59.128:7001 to 192.168.59.129:7003
Adding replica 192.168.59.129:7005 to 192.168.59.128:7000
Adding replica 192.168.59.128:7002 to 192.168.59.129:7004
M: bbf1f1150a661ec3adee9ecb37ab140c03290582 192.168.59.128:7000
   slots:5461-10922 (5462 slots) master
S: 046219f4f154a5a757877cd1dc0f186423942424 192.168.59.128:7001
   replicates ccd1c5d708b1844881c13ac4c6ac467574ff23f7
S: f5e01feb8dd6f085c3b25c35f25753f6b2fa750b 192.168.59.128:7002
   replicates c7af24dcbe0ea6c26aec9965573c82130e98718a
M: ccd1c5d708b1844881c13ac4c6ac467574ff23f7 192.168.59.129:7003
   slots:0-5460 (5461 slots) master
M: c7af24dcbe0ea6c26aec9965573c82130e98718a 192.168.59.129:7004
   slots:10923-16383 (5461 slots) master
S: 0b9385e4fb3a939414891a00585f65c2fa07c29b 192.168.59.129:7005
   replicates bbf1f1150a661ec3adee9ecb37ab140c03290582
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 192.168.59.128:7000)
M: bbf1f1150a661ec3adee9ecb37ab140c03290582 192.168.59.128:7000
   slots:5461-10922 (5462 slots) master
   1 additional replica(s)
S: 046219f4f154a5a757877cd1dc0f186423942424 192.168.59.128:7001
   slots: (0 slots) slave
   replicates ccd1c5d708b1844881c13ac4c6ac467574ff23f7
S: 0b9385e4fb3a939414891a00585f65c2fa07c29b 192.168.59.129:7005
   slots: (0 slots) slave
   replicates bbf1f1150a661ec3adee9ecb37ab140c03290582
M: ccd1c5d708b1844881c13ac4c6ac467574ff23f7 192.168.59.129:7003
   slots:0-5460 (5461 slots) master
   1 additional replica(s)
S: f5e01feb8dd6f085c3b25c35f25753f6b2fa750b 192.168.59.128:7002
   slots: (0 slots) slave
   replicates c7af24dcbe0ea6c26aec9965573c82130e98718a
M: c7af24dcbe0ea6c26aec9965573c82130e98718a 192.168.59.129:7004
   slots:10923-16383 (5461 slots) master
   1 additional replica(s)
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.

redis3.2.6 集群安装的更多相关文章

  1. redis3.0.0 集群安装详细步骤

    Redis集群部署文档(centos6系统) Redis集群部署文档(centos6系统) (要让集群正常工作至少需要3个主节点,在这里我们要创建6个redis节点,其中三个为主节点,三个为从节点,对 ...

  2. redis3.0.5集群部署安装详细步骤

    Redis集群部署文档(centos6系统) (要让集群正常工作至少需要3个主节点,在这里我们要创建6个redis节点,其中三个为主节点,三个为从节点,对应的redis节点的ip和端口对应关系如下) ...

  3. CentOS下redis集群安装

    环境: 一台CentOS虚拟机上部署六个节点,创建3个master,3个slave节点 1.下载并解压 cd /root wget http://download.redis.io/releases/ ...

  4. redis离线集群安装

    用一个叫redis-trib.rb的ruby脚本.redis-trib.rb是redis官方推出的管理redis集群的工具,集成在redis的源码src目录下(redis-xxx/src/).是基于r ...

  5. 缓存系列之五:通过codis3.2实现redis3.2.8集群的管理

    通过codis3.2实现redis3.2.8集群 一:Codis 是一个分布式 Redis 解决方案, 对于上层的应用来说, 连接到 Codis Proxy 和连接原生的 Redis Server 没 ...

  6. Redis Sentinel 集群安装 step by step

    一. 准备材料 服务器 IP address 操作系统 位数 Redis 版本   CNT06CAH05 192.168.3.47 CentOS 6.5 x64 Redis-3.2.6 sentine ...

  7. Redis-3.2.1集群内网部署

    摘要: Redis-3.2.1集群内网部署 http://rubygems.org国内连不上时的一种Redis集群部署解决方案.不足之处,请广大网友指正,谢谢! 一. 关于redis cluster  ...

  8. redis cluster 集群 安装 配置 详解

    redis cluster 集群 安装 配置 详解 张映 发表于 2015-05-01 分类目录: nosql 标签:cluster, redis, 安装, 配置, 集群 Redis 集群是一个提供在 ...

  9. 【Oracle 集群】Oracle 11G RAC教程之集群安装(七)

    Oracle 11G RAC集群安装(七) 概述:写下本文档的初衷和动力,来源于上篇的<oracle基本操作手册>.oracle基本操作手册是作者研一假期对oracle基础知识学习的汇总. ...

随机推荐

  1. matlab 2016a破解中文版安装教程

    之前电脑重装过,所以要重新安装一个matlab,在大三的时候学过matlab,信息老师给的安装包,但是不知道放哪里去了,记忆力不好,找了些网上的教程和下载地址,真的是坑,一些都是不行的,在这里记录下m ...

  2. 20170410 --- Linux备课资料 --- vim的使用

    首先我们要了解一下什么是vim? -----> vim是从vi发展出来的一个文本编辑器. 那问题又来了,什么是vi呢? ------> vi 是Unix like (可以理解为linux) ...

  3. Map和Set

    JavaScript的默认对象表示方式{}可以视为其他语言中的Map或Dictionary的数据结构,即一组键值对. 但是JavaScript的对象有个小问题,就是键必须是字符串.但实际上Number ...

  4. 解决failed to push some refs to

    由于github我使用了dev和feature分支,团队合作合并到dev,个人开发都是feature....今天在本地feature中git pull origin dev 出现 在使用git 对源代 ...

  5. loopj.com android-async-http

    loopj.com android-async-http Android异步Http客户端 用于Android的基于回调的Http客户端库   下载版本1.4.9(最新) 或者在github上fork ...

  6. 用C写一个web服务器(三) Linux下用GCC进行项目编译

    .container { margin-right: auto; margin-left: auto; padding-left: 15px; padding-right: 15px } .conta ...

  7. Http协议---Hyper Text Transfer Protocol

    HTTP是一个基于TCP/IP通信协议来传递数据(超文本传输协议) 好久木来更新文章了~我又回归了,此刻鼓掌...... 今天就来分享下http协议的小知识,在接口测试中我们最常接触的HTTP协议,那 ...

  8. TC SRM683 Div1 250

    大意是有一排石子,每一堆有a[i]个,目标状态每一堆有b[i]个,每一步可以从一堆中取出一个石子转移到相邻的一个,其中1和n也算相邻也即环形.问最少步数. 比赛的时候写了个按照步数贪心的做法,FST了 ...

  9. Java数据结构和算法

    首先,本人自学java,但是只学习了java的基础知识,所以想接下来学习一下数据结构和算法,但是找了很多教材,大部分写的好的都是用c语言实现的,虽然知道数据结构和算法,跟什么语言实现的没有关系,但是我 ...

  10. webrtc学习笔记1(建立连接基本流程)

    最近在做一个基于webrtc的视频软件,以下是自己对于上层建立通话连接流程的基本理解,记录于此. 假设A和B要建立视频通话,A为房间创建端,B为加入房间端: 1.A通过http登录.获取其他服务器地址 ...