转载请注明出处哈:http://carlosfu.iteye.com/blog/2240426
安装视频:
一、目的
为什么官方提供了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
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)
<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
相关推荐
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
初始化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集群配置文件 redis-cluster
搭建redis集群文件,内含六个redis,文件配置已经全部修改好了,1、先在服务器安装下yum install ruby 和 yum install rubygems 2、然后解压文件上传到linux服务器 3、./redis-cluster-start-all.sh 开启reids 4、...
本文参考官方文档而成:http://redis.io/topics/cluster-tutorial,不适用redis-5.0.0以下版本,原因是从redis-5.0.0版本开始,redis-trib.rb的功能被redis-cli替代了。 redis-5.0.0以下版本的安装和部署,可...
Check `redis-cli --cluster help` for more info. 5. New sorted set commands: ZPOPMIN/MAX and blocking variants. 6. Active defragmentation version 2. 7. Improvemenets in HyperLogLog implementations. 8....
redis-4.0.11包通过centos7 make编译,在目录src下有redis-trib.rb、redis-cli、redis-server可以直接使用,搭建redis-cluster集群。
Redis 5.0 is the first version of Redis to introduce the new stream data type with consumer groups, sorted sets blocking pop operations, LFU/LRU info in RDB, Cluster manager inside redis-cli, active ...
osx上Docker中的Redis集群使用7000〜7005的端口启动redis集群bash start.sh连接到集群 redis-cli -c -p 7000停止集群 docker-compose down安装redis-cli brew install redis-clicli中的示例输出 ○ → redis-cli -c ...
Chapter 5, Clients for Your Favorite Language (Become a Redis Polyglot), shows how to use Redis with PHP, Python, and Ruby. This chapter highlights the features that vary more frequently with clients ...
Redis 6 RC1 发布了,项目创建人 antirez 在博客中介绍,这是迄今最“企业”化的版本(SSL 与 ACL 等特性与企业极相关)...Redis Cluster 代理与 Redis 6 一起发布(不同仓库) Redis 6 发布 Disque 模块(不同仓库)
Redis Cluster Vagrant...无所事事地无所事事ssh redis01 redis-cli -a pass --cluster create 10.11.8.2:6379 10.11.8.3:6379 10.11.8.4:6379 10.11.8.5:6379 10.11.8.6:6379 10.11.8.7:6379 --cluster-replicas 1个
redis-6.0.3 最新版exe可执行文件,redis6最大变化 就是加入了对多线程的支持。 一、对用户使用有直接影响的功能 ACL用户权限控制功能 RESP3:新的 Redis 通信协议 Cluster 管理工具 SSL 支持 二、Redis 内部的优化...
1、在java程序中,连接不上redisCluster。 报错信息: no reachable node in cluster 原因:创建集群时,使用了127.0.0.1,要改为公网ip才行。 redis-cli –cluster create 127.0.0.1:7001 127.0.0.1:7002 解决方法...
通过`redis-cli --cluster help`以了解更多信息 新的 sorted set 命令:ZPOPMIN / MAX 和阻塞变量 主动碎片整理 V2 增强 HyperLogLog 实现 更好的内存统计报告 许多带有子命令的命令现在都有一个 HELP 子命令 ...
2018年十月 Redis 发布了稳定版本的 5.0 版本,推出了各种新特性,其中一点是放弃 Ruby的集群方式,改为 使用 C语言编写的 redis-cli的方式,是集群的构建方式复杂度大大降低。关于集群的更新可以在 Redis5 的版本...
安装 redis-cli 可能使用 apt-get install redis-server docker pull redis docker pull joshula/redis-sentinel 跑步 provision_docker_redis_cluster.sh 删除集群 remove_docker_redis_cluster.sh 玩它 附加到...
redis-aof-to-plain-converter 用于将数据从 aof 文件导入到具有不同配置的新 redis-cluster 的简单工具工具转换 *2$6SELECT$10*8$5HMSET$13HSET:USER:cms$8password$40fdaad7328c6da36e8cc63409d6acc5109bfa463b$10...
Redis 中有删除单个 Key 的指令 DEL,但...//如:/opt/redis/redis-cli keys “*” | xargs /opt/redis/redis-cli del 如果要指定 Redis 数据库访问密码,使用下面的命令: 代码如下: redis-cli -a password keys “*
Redis 5.0 is the first version of Redis to introduce the new stream data type with consumer groups, sorted sets blocking pop operations, LFU/LRU info in RDB, Cluster manager inside redis-cli, active ...