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

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

博客分类:

redis
缓存
redis-cluster
redisCluster指派槽cluster-infomeetslots
转载请注明出处哈: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. 下载、编译、安装

Java代码
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. 配置目录、数据目录

Java代码
cd /opt/soft/redis-3.0.3
mkdir -p data
mkdir -p conf

3.建立软链接:

Java代码
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是六个端口号

Java代码
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个文件

Java代码
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个节点。

Java代码
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. 查看节点是否都已经启动:

Java代码
[@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)

Java代码
[@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 所指定的节点添加到集群当中,让它成为集群的一份子。

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

Java代码
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)指派(assign)给当前节点。

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

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

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

Java代码
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当前状态 .

Java代码
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. 确认分配槽状态:

Java代码
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 指定的节点的从节点。

    8003设置成8000的从

    8004设置成8001的从

    8005设置成8002的从

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

Java代码
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}'

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

Java代码
集群状态:
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

Original: https://www.cnblogs.com/archoncap/p/6149672.html
Author: archoncap
Title: Redis-Cluster实战–5.使用redis-cli安装

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/529030/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • zabbix用户,角色,权限,模板管理

    zabbix用户,角色,权限,模板管理 zabbix用户,角色,权限,模板管理 用户组用户角色右上角是创建角色用户lnh@1234使用刚才创建的用户登录模板组模板模板的监控项可以自…

    Linux 2023年6月6日
    0113
  • 数据结构-表

    顺序表 #ifndef SEQLIST_H #define SEQLIST_H typedef int DataType; struct Node { int MaxNum; in…

    Linux 2023年6月7日
    071
  • Android(Java)控制GPIO的方法及耗时分析

    前面两篇分别介绍了通过脚本和C代码读写/sys/class/gpio以控制GPIO。实际项目调试时经常还需要在Java代码里控制GPIO,其实现与C代码类似,唯一不同是Androi…

    Linux 2023年6月7日
    090
  • Redis 的 5 个常见使用场景

    在这篇文章中,我们将阐述 Redis 最常用的使用场景,以及那些影响我们选择的不同特性。 最常用的一种使用Redis的情景是会话缓存(session cache)。用Redis缓存…

    Linux 2023年5月28日
    0108
  • MySQL注入流程

    确认注入点 信息收集 数据获取 提权 写个MySQL注入流程的大纲,类似一份全局地图,能指导下一步工作。MySQL注入流程分为四步: 确认注入点 信息收集 数据获取 提权 确认注入…

    Linux 2023年6月6日
    0118
  • Redis从入门到精通:中级篇

    原文链接:http://www.cnblogs.com/xrq730/p/8944539.html,转载请注明出处,谢谢 本文目录 上一篇文章以认识Redis为主,写了Redis系…

    Linux 2023年5月28日
    096
  • MySQL启动报:[ERROR] The server quit without updating PID file

    修改配置后 MySQL启动不了,报错: 看见这个不要惊慌,先把刚才修改的配置注释掉,看是不是配置有误!大部分是手误造成。 如果不行,再尝试一下方法: 解决方法 : 给予权限,执行 …

    Linux 2023年6月13日
    080
  • Redis 基础

    Redis 基础 Redis 定位 – 特性 关系型数据库 特性 非关系型数据库 特性 Redis 特性 Redis 安装 – 启动 – 使用 …

    Linux 2023年6月13日
    0139
  • shell join详解

    首先贴一个,join –help 然后来理解下。 join 【命令选项】 文件1 文件2 //命令选项可以很多, 但文件只能是两个 先从重要的开始说,join 的作用是…

    Linux 2023年5月28日
    073
  • 019 Linux tcpdump 抓包案例入门可真简单啊?

    1 tcpdump 是什么? 2 tcpdump 常用命令参数 3 tcpdump 抓包wss,配合Wireshark分析 4 tcpdump 抓包白度,配合Wireshark分析…

    Linux 2023年5月27日
    082
  • 关于如何在Idea下进行多子项目及引用内部子项目情况下打包项目的方法

    近期在开发Java的时候遇到了如下的打包上的问题 需要将一个工程下面的子工程分别打包 有的子工程还包含了另一个子工程 在这种情况下打包会出现找不到子模块的情况。 JDK:1.8 开…

    Linux 2023年6月14日
    095
  • Redis基础教程

    redis基础教程 1、 string数据结构 a) SET server:name “fido” b) SETNX server:name1″…

    Linux 2023年5月28日
    079
  • Java刷题笔记7.25

    一个类构造方法的作用是什么? 主要是完成对&am…

    Linux 2023年6月7日
    0108
  • jdk8 线程池策略

    在ThreadPoolExecutor中提供了4种线程的策略可以供开发者直接使用:•AbortPolicy策略:默认策略,如果线程池队列满了丢掉这个任务并且抛出RejectedEx…

    Linux 2023年6月8日
    0117
  • 基于redis分布式锁实现“秒杀”

    转载:http://blog.5ibc.net/p/28883.html 最近在项目中遇到了类似”秒杀”的业务场景,在本篇博客中,我将用一个非常简单的dem…

    Linux 2023年5月28日
    0105
  • tp5,把耗时操作转为队列,queue + redis + supervisor消息推送(队列的执行异步不异步不知道,workman,swoole可以异步)

    添加队列 /** * 发送一个推送 * @param mixed client_id 设备号(字符串/数组) 1 * @param int group 分组(如:1=用户端2=骑手…

    Linux 2023年5月28日
    082
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球