`
carlosfu
  • 浏览: 576820 次
  • 性别: Icon_minigender_1
  • 来自: 北京
博客专栏
Ba8b5055-9c58-3ab0-8a1c-e710f0495d2c
BigMemory实战与理...
浏览量:30528
53b2087e-c637-34d2-b61d-257846f73ade
RedisCluster开...
浏览量:150211
C9f66038-7478-3388-8086-d20c1f535495
缓存的使用与设计
浏览量:123524
社区版块
存档分类
最新评论

Redis-Cluster实战--5.使用redis-cli安装

阅读更多

转载请注明出处哈:http://carlosfu.iteye.com/blog/2240426


安装视频:

    8.2.2 redis-cluster安装1

    8.2.3 redis-cluster安装2

    8.2.4 redis-cluster安装纠正   

 

一、目的
     为什么官方提供了ruby构建集群工具,还要实现一个redis-cli版的集群构建?
    答案很简单:
    1. 熟悉redis-cluster的集群命令和协议(作者给的ruby工具都是在这些命令组合起来)
    2. 更好的理解redis-cluster
    注意:
本文档只为了演示redis-cli搭建Redis-Cluster,实际大集群还是以工具(例如ruby, 其他语言封装的自动化安装工具为第一选择)。
 

、准备redis(下载、编译、安装、配置目录、数据目录)

 

1. 下载、编译、安装

cd /opt/soft
wget http://download.redis.io/releases/redis-3.0.3.tar.gz
tar xzf redis-3.0.3.tar.gz
cd redis-3.0.3
make
make install

 

2. 配置目录、数据目录

cd /opt/soft/redis-3.0.3
mkdir -p data
mkdir -p conf

 

3.建立软链接:

ln -s /opt/soft/redis-3.0.3 /opt/soft/redis

 

 

二、配置、启动Redis节点(本例子以3主、3从组成Redis-Cluster)

 
实际中应该在多台机器进行安装,这里为了方便演示只用了一台机器,ip=10.10.53.159。

 

 

1. 配置redis节点,在conf目录下添加6个(8000-8005)redis-${port}.conf作为6个节点的配置文件

      其中8000-8005是六个端口号

port 8000
cluster-enabled yes
cluster-config-file nodes-8000.conf
cluster-node-timeout 15000
dir "/opt/soft/redis/data/"
appendonly yes
appendfilename "appendonly-8000.aof"
logfile "8000.log"
daemonize yes
pidfile /var/run/redis-8000.pid 
dbfilename "dump-8000.rdb"

 

    生成另外5个文件

sed 's/8000/8001/g' redis-8000.conf > redis-8001.conf
sed 's/8000/8002/g' redis-8000.conf > redis-8002.conf
sed 's/8000/8003/g' redis-8000.conf > redis-8003.conf
sed 's/8000/8004/g' redis-8000.conf > redis-8004.conf
sed 's/8000/8005/g' redis-8000.conf > redis-8005.conf

  

 

2. 启动6个节点。

redis-server /opt/soft/redis/conf/redis-8000.conf
redis-server /opt/soft/redis/conf/redis-8001.conf
redis-server /opt/soft/redis/conf/redis-8002.conf
redis-server /opt/soft/redis/conf/redis-8003.conf
redis-server /opt/soft/redis/conf/redis-8004.conf
redis-server /opt/soft/redis/conf/redis-8005.conf

 

 

3. 查看节点是否都已经启动:

[@zw_53_162 conf]# ps -ef | grep redis
root 26007 1 0 21:56 ? 00:00:00 redis-server *:8000 [cluster] 
root 26011 1 0 21:56 ? 00:00:00 redis-server *:8001 [cluster] 
root 26019 1 0 21:56 ? 00:00:00 redis-server *:8002 [cluster] 
root 26023 1 0 21:56 ? 00:00:00 redis-server *:8003 [cluster] 
root 26033 1 0 21:56 ? 00:00:00 redis-server *:8004 [cluster] 
root 26047 1 0 21:56 ? 00:00:00 redis-server *:8005 [cluster]

 

 

4. 查看单个节点:(此时六个节点是分散的,没有形成集群,所有cluster_state=fail)

 

[@zw_53_162 conf]# redis-cli -c -p 8000
127.0.0.1:8000> cluster info
cluster_state:fail
cluster_slots_assigned:0
cluster_slots_ok:0
cluster_slots_pfail:0
cluster_slots_fail:0
cluster_known_nodes:1
cluster_size:0
cluster_current_epoch:0
cluster_my_epoch:0
cluster_stats_messages_sent:0
cluster_stats_messages_received:0

 

 

四、利用redis-cluster meet命令,实现节点握手,组成集群:

 

cluster meet <ip> <port> 将 ip 和 port 所指定的节点添加到集群当中,让它成为集群的一份子。

   

 

 1. 利用redis-cli连接到8000,然后meet 8001-8005

redis-cli -c -p 8000 cluster meet 10.10.53.159 8001
redis-cli -c -p 8000 cluster meet 10.10.53.159 8002
redis-cli -c -p 8000 cluster meet 10.10.53.159 8003
redis-cli -c -p 8000 cluster meet 10.10.53.159 8004
redis-cli -c -p 8000 cluster meet 10.10.53.159 8005

 

  

五、分配槽(slots)给节点:

       

     1. 分派slots

 

cluster addslots <slot> [slot ...] 将一个或多个槽(slot)指派(assign)给当前节点。

 

     redis-cli -c -p 8000 cluster addslots 0 1 2 ...

    (redis-cli 未实现0-5462这样的参数,必须一个个输入。)

    所以利用shell生成最终的命令addslots.sh:

 

start=$1
end=$2
port=$3
for slot in `seq ${start} ${end}`
do
    echo "slot:${slot}"
	redis-cli -c -p ${port} cluster addslots ${slot} 
done

 

    执行: 

sh addslots.sh 0 5460 8000
sh addslots.sh 5461 10922 8001
sh addslots.sh 10923 16383 8002

 


   2. 确认cluster当前状态 .

 

127.0.0.1:8000> cluster info
cluster_state:ok
cluster_slots_assigned:16384
cluster_slots_ok:16384
cluster_slots_pfail:0
cluster_slots_fail:0
cluster_known_nodes:6
cluster_size:3
cluster_current_epoch:5
cluster_my_epoch:1
cluster_stats_messages_sent:1650
cluster_stats_messages_received:1650

 

  3. 确认分配槽状态:

127.0.0.1:8000> cluster nodes
6690722c4536210a231af4bdceb604e83d53403e 10.10.53.159:8001 master - 0 1440897737597 3 connected 5461-10922
4d2842d9f846481783eafbd9135df372e2153307 10.10.53.159:8000 myself,master - 0 0 1 connected 0-5460
caefaab1e5d01d76a728c84cb1dc285a6aab15a6 10.10.53.159:8005 master - 0 1440897736092 4 connected
ec403c50e59460bcb0b47906e567423b7d9aed50 10.10.53.159:8003 master - 0 1440897738097 0 connected
a52b9d211ec06190bcc4ab36eecf643fa13aa215 10.10.53.159:8004 master - 0 1440897736594 5 connected
c05ebacbeeb6cbcf52a6ac60384891586226f131 10.10.53.159:8002 master - 0 1440897737096 2 connected 10923-16383

127.0.0.1:8000> cluster slots
1) 1) (integer) 5461
 2) (integer) 10922
 3) 1) "10.10.53.159"
 2) (integer) 8001
2) 1) (integer) 0
 2) (integer) 5460
 3) 1) "10.10.53.159"
 2) (integer) 8000
3) 1) (integer) 10923
 2) (integer) 16383
 3) 1) "10.10.53.159"
 2) (integer) 8002

  

 

六、配置主从关系(保证高可用):

 

cluster replicate <node_id> 将当前节点设置为 node_id 指定的节点的从节点。

 

    8003设置成8000的从

    8004设置成8001的从

    8005设置成8002的从

 

注意这里的命令不是slaveof
<node_id>不是ip:port的形式,需要查询cluster nodes查找自己的node_id(myself)

  

redis-cli -c -p 8003 cluster  replicate `redis-cli -c -p 8003 cluster nodes | grep 8000 | awk '{print $1}'`
redis-cli -c -p 8004 cluster  replicate `redis-cli -c -p 8003 cluster nodes | grep 8001 | awk '{print $1}'`
redis-cli -c -p 8005 cluster  replicate `redis-cli -c -p 8003 cluster nodes | grep 8002 | awk '{print $1}'`

 

 

 

七、最终确认集群状态、节点状态、分配槽状态:

 

集群状态:
127.0.0.1:8000> cluster info
cluster_state:ok
cluster_slots_assigned:16384
cluster_slots_ok:16384
cluster_slots_pfail:0
cluster_slots_fail:0
cluster_known_nodes:6
cluster_size:3
cluster_current_epoch:5
cluster_my_epoch:1
cluster_stats_messages_sent:2963
cluster_stats_messages_received:2963
 
三主三从
127.0.0.1:8000> cluster nodes 
6690722c4536210a231af4bdceb604e83d53403e 10.10.53.159:8001 master - 0 1440897872917 3 connected 5461-10922
4d2842d9f846481783eafbd9135df372e2153307 10.10.53.159:8000 myself,master - 0 0 1 connected 0-5460
caefaab1e5d01d76a728c84cb1dc285a6aab15a6 10.10.53.159:8005 slave c05ebacbeeb6cbcf52a6ac60384891586226f131 0 1440897874922 4 connected
ec403c50e59460bcb0b47906e567423b7d9aed50 10.10.53.159:8003 slave 4d2842d9f846481783eafbd9135df372e2153307 0 1440897874922 1 connected
a52b9d211ec06190bcc4ab36eecf643fa13aa215 10.10.53.159:8004 slave 6690722c4536210a231af4bdceb604e83d53403e 0 1440897874421 5 connected
c05ebacbeeb6cbcf52a6ac60384891586226f131 10.10.53.159:8002 master - 0 1440897873920 2 connected 10923-16383
 
分配槽状态:
127.0.0.1:8000> cluster slots
1) 1) (integer) 10923
   2) (integer) 16383
   3) 1) "10.10.53.159"
      2) (integer) 8002
   4) 1) "10.10.53.159"
      2) (integer) 8005
2) 1) (integer) 5461
   2) (integer) 10922
   3) 1) "10.10.53.159"
      2) (integer) 8001
   4) 1) "10.10.53.159"
      2) (integer) 8004
3) 1) (integer) 0
   2) (integer) 5460
   3) 1) "10.10.53.159"
      2) (integer) 8000
   4) 1) "10.10.53.159"
      2) (integer) 8003

  

 

 

  • 大小: 84.5 KB
分享到:
评论
2 楼 carlosfu 2017-07-17  
yanan0628 写道



爷大帝
1 楼 yanan0628 2017-07-17  

相关推荐

    redis-cluster.tar.gz

    Redis 是一个高性能的键值数据库,常用于数据缓存、消息队列以及数据库等功能。...通过深入理解 Redis Cluster 的工作原理和使用方法,你可以更好地优化和利用 Redis 在大数据量场景下的性能优势。

    redis-cluster-5.0.7.tar.gz

    2. **创建集群**:使用`redis-cli`的`--cluster create`命令,提供所有节点的IP和端口,这将创建一个空的集群,并在每个节点间建立连接。 3. **分配槽位**:Redis Cluster将数据空间划分为16384个槽位(slots)。你...

    redis5离线安装文件包,包含redis-5.0.14.tar.gz和redis-4.6.0.gem

    redis-5.0.14/src/redis-cli --cluster create 192.168.129.98:7000 192.168.129.99:7003 192.168.129.99:7002 192.168.129.126:7005 192.168.129.126:7004 192.168.129.98:7001 --cluster-replicas

    Windows环境Redis-Cluster配置

    1. 初始化节点:启动三个或更多的Redis实例,并使用redis-cli工具初始化节点,命令类似于`redis-cli --cluster create node1:port node2:port ... --cluster-replicas 1`,其中`node1:port`、`node2:port`为各个节点...

    docker-redis-cluster-master.tar.gz 集群

    初始化3主3从集群redis-cli --cluster create 192.168.0.224:6391 192.168.0.224:6392 192.168.0.224:6393 192.168.0.224:6394 192.168.0.224:6395 192.168.0.224:6396 --cluster-replicas 1 连接集群测试 redis-cli...

    redis-3.0.0.tar和redis-3.0.0.gem.rar

    5. **初始化集群**:使用`redis-cli --cluster create`命令,指定所有节点的IP和端口,创建集群。 6. **分配槽**:集群会自动分配槽,或者可以通过`--cluster-replicas`参数手动设置副本节点数量。 7. **客户端连接*...

    redis-cluster开箱即用作者已经实验

    这个压缩包“redis-cluster”应该是包含了一组配置好的Redis Cluster环境,可以快速部署,省去了手动安装和配置的繁琐过程。 在Redis Cluster中,每个节点都是一个独立的Redis服务器,它们共同构成了一个集群。集群...

    redis集群安装 redis 6.x 安装包 redis-6.2.1_install.tar.gz

    8. **监控与维护**:持续监控集群健康状况,使用 `redis-cli cluster nodes` 查看节点状态,定期执行 `redis-cli cluster meet` 添加新节点或恢复故障节点。 完成上述步骤后,你就成功搭建了一个基本的 Redis 6.x ...

    docker-redis-cluster集群安装

    【标题】:Docker Redis Cluster集群安装指南 在IT行业中,Redis被广泛用作高性能的内存数据存储,常用于数据库、缓存以及消息代理。而Redis Cluster是Redis的一个分布式解决方案,能够提供高可用性和可扩展性。本...

    redis-cluster redis伪集群文件

    搭建redis集群文件,内含六个redis,文件配置已经全部修改好了,1、先在服务器安装下yum install ruby 和 yum install rubygems 2、然后解压文件上传到linux服务器 3、./redis-cluster-start-all.sh 开启reids 4、...

    Redis-x64-5.0.14.1.msi

    在 Windows 上,可以使用 `redis-cli.exe` 连接到本地或远程 Redis 实例。 10. **配置与优化**:Redis 可以通过配置文件 `redis.conf` 进行设置,包括内存限制、日志级别、持久化策略等。根据实际需求进行适当调整...

    完整搭建redis-cluster

    使用 `redis-cli` 的 `CLUSTER` 命令,如 `CLUSTER NODES` 和 `CLUSTER INFO`。 ### 8. 扩展与缩容 随着数据量的增长,可能需要增加或减少节点。使用 `redis-trib.rb reshard` 命令进行扩展,根据需要平衡槽区分布...

    redis安装文件Redis-x64-3.2.10、Redis-x64-3.0.50

    4. 测试连接:使用Redis客户端工具(如`redis-cli`)连接到本地服务器,验证Redis是否正常工作。可以尝试发送一些基本命令,如`SET key value`、`GET key`等。 5. 安全设置:生产环境中,为了安全,你需要设置访问...

    最新版windows Redis-x64-5.0.14.1.zip

    安装完成后,你可以通过Redis的命令行客户端`redis-cli`与Redis服务器交互,执行各种操作。同时,Windows版本的Redis还提供了一个名为`redis-server.exe`的服务可执行文件,用于启动和管理Redis服务器。在配置文件`...

    Redis-Cluster 分布式集群.docx

    1. 使用`redis-cli --cluster create`命令创建集群。这个命令需要提供所有初始节点的IP地址和端口号,以及集群副本的数量(默认为1)。例如: ``` redis-cli --cluster create 192.168.65.2:7000 192.168.65.2:...

    Redis-x64-3.2.100-稳定版.rar

    5. **客户端连接**:Redis 提供了命令行客户端 `redis-cli.exe`,可用于交互式操作。在命令行输入 `redis-cli.exe -h localhost -p 6379`(默认端口)可连接到本地 Redis 服务器,进行键值对的增删查改。 6. **数据...

    Redis-x64-5.0.14.1.zip

    2. **redis-cli.exe**:这是一个命令行接口工具,用于与Redis服务器交互。你可以通过它来发送命令、查看数据、执行操作以及管理Redis实例。例如,你可以使用`ping`命令检查服务器状态,`SET key value`命令存储数据...

    linux redis安装(redis-2.6.14.tar.gz)

    要检查Redis是否正常运行,可以使用`redis-cli`命令: ```bash /usr/local/bin/redis-cli ``` 在客户端模式下,你可以尝试一些基本的Redis命令,如`SET`和`GET`: ```bash SET mykey "Hello, World!" GET mykey `...

    Redis-x64-3.2.100免安装版配置+linux版.zip

    安装完成后,你可以通过`/etc/init.d/redis start`启动Redis服务,使用`redis-cli`进行交互操作。 Redis的配置通常在`redis.conf`文件中进行,包括端口设置(默认6379)、日志文件路径、数据库数量、持久化策略...

Global site tag (gtag.js) - Google Analytics