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

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: 转载请注明出处哈:http://carlosfu.iteye.com/blog/2240426 安装视频:     8.2.2 redis-cluster安装1     8.2.

转载请注明出处哈: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

  

 

 

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
2天前
|
存储 NoSQL Redis
Redis数据结构精讲:选择与应用实战指南
Redis数据结构精讲:选择与应用实战指南
12 0
|
2天前
|
NoSQL Redis Docker
Mac上轻松几步搞定Docker与Redis安装:从下载安装到容器运行实测全程指南
Mac上轻松几步搞定Docker与Redis安装:从下载安装到容器运行实测全程指南
13 0
|
3天前
|
NoSQL Linux Redis
本地虚拟机centos7通过docker安装主从redis3.2
本地虚拟机centos7通过docker安装主从redis3.2
10 0
|
4天前
|
NoSQL Linux Redis
Redis的介绍,以及Redis的安装(本机windows版,虚拟机Linux版)和Redis常用命令的介绍
Redis的介绍,以及Redis的安装(本机windows版,虚拟机Linux版)和Redis常用命令的介绍
17 0
|
11天前
|
监控 NoSQL 算法
探秘Redis分布式锁:实战与注意事项
本文介绍了Redis分区容错中的分布式锁概念,包括利用Watch实现乐观锁和使用setnx防止库存超卖。乐观锁通过Watch命令监控键值变化,在事务中执行修改,若键值被改变则事务失败。Java代码示例展示了具体实现。setnx命令用于库存操作,确保无超卖,通过设置锁并检查库存来更新。文章还讨论了分布式锁存在的问题,如客户端阻塞、时钟漂移和单点故障,并提出了RedLock算法来提高可靠性。Redisson作为生产环境的分布式锁实现,提供了可重入锁、读写锁等高级功能。最后,文章对比了Redis、Zookeeper和etcd的分布式锁特性。
118 16
探秘Redis分布式锁:实战与注意事项
|
12天前
|
NoSQL Redis Docker
使用docker安装redis
该文档介绍了如何使用Docker快速搭建Redis数据库,以便于Spring Boot学习。主要内容包括获取Redis镜像、创建容器、配置持久化存储目录和修改默认配置文件,以及检查和访问Redis容器服务。此外,还提到若需外部访问,需开启宿主机防火墙相应端口。注意,本教程不深入讲解Docker,若想深入学习Docker,建议另寻专门课程。
|
13天前
|
NoSQL Redis
mac下安装redis
mac下安装redis
|
13天前
|
消息中间件 监控 NoSQL
【亮剑】如何排查和解决Redis高负载问题
【4月更文挑战第30天】本文介绍了如何排查和解决Redis高负载问题。通过监控CPU、内存、网络IO和命令处理速度,可识别性能瓶颈。排查包括:分析慢查询、内存使用、网络连接和命令执行。优化措施涉及优化查询、减少复杂命令、使用连接池、调整数据结构等。建立监控系统、定期性能测试和持续优化是关键。
|
1月前
|
存储 NoSQL 算法
09- Redis分片集群中数据是怎么存储和读取的 ?
Redis分片集群使用哈希槽分区算法,包含16384个槽(0-16383)。数据存储时,通过CRC16算法对key计算并模16383,确定槽位,进而分配至对应节点。读取时,根据槽位找到相应节点直接操作。
68 12
|
3天前
|
存储 监控 NoSQL
Redis哨兵&分片集群
Redis哨兵&分片集群
7 0