第九课时作业

静哥

by 2016.4.18~2016.4.25

1、节点

(1)节点概念:一个节点就是redis集群里的一台redis服务器。一个redis集群是由多个节点(node)组成,最初每个节点是相互独立的,可以理解成都处于一个只包含自己的集群当中,要组建一个真正可用的集群环境,必须将各个独立的节点连接起来。

(2)将一个redis服务器以集群模式启动:

Redis服务器在启动时会根据cluster-enabled参数选项来决定是否开启集群模式;

(3)节点之间相互连接成一个集群:

按照(2)中以集群模式分别启动3个redis服务器,分别占用端口6379 、7379、8379。如下:

客户端连接其中一个节点(例如6379端口所在redis服务器),执行cluster meet命令来完成连接各个节点的工作

(4)查看当前集群状态

个节点都没有在处理任何槽,所以集群处于下线状态(fail)

2、槽指派

(1)概念—槽指派:

redis集群是通过分片方式来存储键值的,集群默认将整个redis数据库分成16384个槽(slot)(index从0到16383),集群里的每个节点可以处理最少0个,最多16384个槽,每个节点处理槽的情况,就需要做槽指派;

需要注意,16384个槽,但凡有一个槽没被指派到,整个集群就处在fail状态;即只有16384个槽全部被指派完,集群才处于上线状态(cluter_state:ok)

(2)槽指派的实现:

16384个槽位必须全部分配完,不同节点不能重复,目前没有按照区间进行分配的命令,只能通过shell脚本:

for i in {0..10000}; do redis-cli -p 8379 cluster addslots $i; done

将槽0…10000指派给10.7.12.98:8379;将槽10001…16383指派给10.7.12.98:7379

通过脚本来实现槽指派:

查看节点上槽分配信息:

集群是上线状态了;

或者:

(3)插入数据进行测试:

当节点发现键所在的槽并非由自己负责处理时,节点会向客户端返回一个MOVED错误,指引客户端转向至正在负责槽的节点,MOVED错误格式是:

MOVED <slot> <ip>:<port>

Redis-cli命令不带-c参数,表示单点客户端模式,单点客户端模式下,客户端会打印MOVED错误,不会字自动进行节点转向;

下图,带上-c参数,表示集群模式的redis-cli客户端,在接收到MOVEDc错误时,不会打印MOVED错误,而是根据MOVED错误自动进行节点转向,并打印转向信息;

一共插入10条数据,如下:

号库,单机redis则可以用select命令选择不同的数据库;

3、重新分片

(1)概念:

Redis集群的重新分片,可以将任意数量已经指派给某个节点的槽改为指派给另一个节点,且相关槽所属的键值也会从源节点被移动给目标节点;

重新分片可以在线(online)进行,重新分片过程中,集群不需要下线,且源节点和目标节点可以继续处理命令请求。

(2)重新分片:

案例:当前,10.7.12.98:8379节点上处理的槽位是0~10000;10.7.12.98:7379节点处理的槽位是10001~16383;

现做重新分片:新增10.7.12.98:6379节点到当前集群,并且将8379节点的槽位重新指派给6379节点,重新指派5000个槽位;

现将6379节点添加到当前集群里

以下是槽位重新指派,要用到redis集群管理软件redis-trib.rb:

publicclass ListTypeTests extends ClusterBaseTests {

@Test

publicvoid testLSetGet() {

// 测试新增和获取

doTest(new Executor() {

@Override

publicvoid execute(ShardedJedis jedis) {

String key = "testLset";

jedis.lpush(key, "test0", "test1");

jedis.rpush(key, "test2");

MatcherAssert.assertThat(jedis.lrange(key, 0, -1), Matchers.contains("test1", "test0", "test2"));

}

});

}

@Test

publicvoid testAddByIndex() {

doTest(new Executor() {

@Override

publicvoid execute(ShardedJedis jedis) {

jedis.lpush("testAddByIndex", "value1");

jedis.lpush("testAddByIndex", "value2");

jedis.rpush("testAddByIndex", "value3");

MatcherAssert.assertThat(jedis.lrange("testAddByIndex", 0, -1), Matchers.contains("value2", "value1", "value3"));

}

});

}

@Test

publicvoid testLength() {

doTest(new Executor() {

@Override

publicvoid execute(ShardedJedis jedis) {

for(inti = 0; i < 10; i++) {

jedis.rpush("testLength", i + "");

}

assertThat(jedis.llen("testLength")).isEqualTo(10);

assertThat(jedis.lindex("testLength", 2)).isEqualTo("2");

}

});

}

publicclass SetTypeTests extends ClusterBaseTests {

@Test

publicvoid testSetGet() {

doTest(new Executor() {

@Override

publicvoid execute(ShardedJedis jedis) {

jedis.sadd("testSet", "value1", "value2", "value3");

MatcherAssert.assertThat(jedis.smembers("testSet"), Matchers.containsInAnyOrder("value1", "value2", "value3"));

}

});

}

@Test

publicvoid testIsMember() {

doTest(new Executor() {

@Override

publicvoid execute(ShardedJedis jedis) {

jedis.sadd("testIsMember", "value1", "value2", "value3", "value1");

assertThat(jedis.sismember("testIsMember", "value2")).isTrue();

}

});

}

}

第九课——redis集群的更多相关文章

  1. redis集群的搭建详细教程

    1 Redis-cluster架构图             redis-cluster投票:容错  (至少要三个才可以,才能超过半数) 架构细节: (1)所有的redis节点彼此互联(PING-PO ...

  2. 快速搭建redis单机版和redis集群版

    单机版 第一步:需要安装redis所需的C语言环境,若虚拟机联网,则执行 yum install gcc-c++ 第二步:redis的源码包上传到linux系统 第三步:解压缩redis   tar ...

  3. Redis集群的离线安装以及原理理解

    一.本文主要是记录一下Redis集群在linux系统下离线的安装步骤,毕竟在生产环境下一般都是无法联网的,Redis的集群的Ruby环境安装过程还是很麻烦的,涉及到很多的依赖的安装,所以写了一个文章来 ...

  4. 6.Redis集群

    redis-cluster[集群]架构图 redis-cluster投票:容错 搭建Ruby环境 集群的搭建过程 连接集群 查看集群的命令 1.1 redis-cluster[集群]架构图 架构细节: ...

  5. Redis集群案例与场景分析

    1.背景 Redis的出现确实大大地提高系统大并发能力支撑的可能性,转眼间Redis的最新版本已经是3.X版本了,但我们的系统依然继续跑着2.8,并很好地支撑着我们当前每天5亿访问量的应用系统.想当年 ...

  6. Java Spring mvc 操作 Redis 及 Redis 集群

    本文原创,转载请注明:http://www.cnblogs.com/fengzheng/p/5941953.html 关于 Redis 集群搭建可以参考我的另一篇文章 Redis集群搭建与简单使用 R ...

  7. Redis集群搭建与简单使用

    介绍安装环境与版本 用两台虚拟机模拟6个节点,一台机器3个节点,创建出3 master.3 salve 环境. redis 采用 redis-3.2.4 版本. 两台虚拟机都是 CentOS ,一台 ...

  8. window下使用Redis Cluster部署Redis集群

    日常的项目很多时候都需要用到缓存.redis算是一个比较好的选择.一般情况下做一个主从就可以满足一些比较小的项目需要.在一些并发量比较大的项目可能就需要用到集群了,redis在Windows下做集群可 ...

  9. Redis集群~windows下搭建Sentinel环境及它对主从模式的实际意义

    回到目录 关于redis-sentinel出现的原因 Redis集群的主从模式有个最大的弊端,就是当主master挂了之前,它的slave从服务器无法提升为主,而在redis-sentinel出现之后 ...

随机推荐

  1. [c#]分析器错误消息: 发现不明白的匹配。

    (1)同样的变量名称 protected System.Web.UI.WebControls.Label lbltitle; protected System.Web.UI.WebControls.L ...

  2. Java常量池解析与字符串intern简介

    在Java应用程序运行时,Java虚拟机会保存一份内部的运行时常量池,它区别于class文件的常量池,是class文件常量池映射到虚拟机中的数据结构. 关于class文件常量池的部分可以参考之前的博文 ...

  3. 【高并发简单解决方案】redis缓存队列+mysql 批量入库+php离线整合

    原文出处: 崔小拽 需求背景:有个调用统计日志存储和统计需求,要求存储到mysql中:存储数据高峰能达到日均千万,瓶颈在于直接入库并发太高,可能会把mysql干垮. 问题分析 思考:应用网站架构的衍化 ...

  4. 每日英语:Online Education a New Frontier in China

    In a country as obsessed with education as China, it makes sense that online teaching has huge poten ...

  5. Centos7上修改mysql数据目录

    通过yum安装的mysql,启动和增加数据库,增加数据如下: [root@wucl-4 lib]# systemctl start mariadb [root@wucl-4 lib]# mysql - ...

  6. poj3250单调栈

    有n只羊,(姑且算是羊吧,也有可能是牛啊猫啊什么之类的),每只羊都有一个身高,前面的羊要看到后面的羊的条件是,后面的羊高度要小于前面的羊,就问各位羊加起来看到的牛多少只....... #include ...

  7. js监听 window.open 关闭事件

    转载自:http://blog.csdn.net/hanshileiai/article/details/41346729 首先创建一个新的对象,这将打开一个弹出这样的: var winObj = w ...

  8. Android4.4之后休眠状态下Alarm不准时的问题

    Android4.4及之后休眠状态下Alarm不准时的问题 为了减轻功耗,延长电池使用时间.Android 4.4及之后的版本号採用非精准闹钟机制.以及休眠状态下的wakeup类型的alarm不会实时 ...

  9. 算法 quick sort

    // ------------------------------------------------------------------------------------------------- ...

  10. 查看、分析memcached使用状态

    访问量上升,数据库压力大,怎么办?好办法是在中间挡一层缓存!这个缓存要求高效,不能比数据库慢,否则服务质量受影响:如果能把数据用hash打散存储到硬盘,也是可以的,不过在内存越来越便宜的今天,还是使用 ...