一、什么是Redis集群

  Redis 集群实现了对Redis的水平扩容,即启动N个redis节点,将整个数据库分布存储在这N个节点中,每个节点存储总数据的1/N。

  Redis 集群通过分区(partition)来提供一定程度的可用性(availability): 即使集群中有一部分节点失效或者无法进行通讯, 集群也可以继续处理命令请求

二、安装环境(CentOS 7)

  执行yum install ruby

  执行yum install rubygems

  设置redisXXX.conf配置文件,把里面6379替换成相应的XXX(XXX代表端口号),一共配置六个,我配置的是6379 6380 6381 6389 6390 6391这6个端口

  

三、集群操作

  1.通过对应的redisXXX.conf配置文件,开启6个redis实例,开启后生成6个对应的nodes-xxx文件

  

  2.进入解压redis-3.2.5.tar.gz后生成的redis-3.2.5文件夹里面的src;例:

    cd /opt/redis-3.2.5/src/

  3.进入目录后,执行下面的语句

    #  --replicas 1 表示对每个主节点创建一个从节点

    ./redis-trib.rb create --replicas 1 本机IP:6379 本机IP:6380 本机IP:6381 本机IP:6389 本机IP:6390 本机IP:6391

   例如我的CentOS的IP为192.168.207.128,其中的端口号为开启的redis实例的端口号:

    ./redis-trib.rb create --replicas 1 192.168.207.128:6379 192.168.207.128:6380 192.168.207.128:6381 192.168.207.128:6389 192.168.207.128:6390 192.168.207.128:6391

   

  4.以集群的方式进去客户端

    redis-cli -c -p 端口号  或者 redis-cli  -p 端口号(下面会讲区别)

  

  5.通过cluster nodes查看集群信息

  

四、相关知识

  1.redis cluster如何分配这6个节点

    一个集群至少要有3个主节点

    在六个节点合体时,使用的命令中 --replicas 1 表示对每个主节点创建一个从节点

    分配原则尽量保证每个主数据库运行在不同的IP地址,每个从库和主库不在一个IP地址上

  2.插槽

    ①:一个 Redis 集群包含 16384 个插槽(hash slot), 数据库中的每个键都属于这 16384 个插槽的其中一个, 集群使用公式 CRC16(key) % 16384 来计算键 key 属于哪个槽, 其中 CRC16(key) 语句用于计算键 key 的 CRC16 校验和 。

    ②:集群中的每个节点负责处理一部分插槽。 举个例子, 如果一个集群可以有主节点, 其中:

      节点 A 负责处理 0 号至 5500 号插槽。
      节点 B 负责处理 5501 号至 11000 号插槽
      节点 C 负责处理 11001 号至 16383 号插槽

  3.登录客户端使用-c与不使用的区别

    使用-c会自动重定向key对应插槽的客户端,不使用-c不会自动重定向,会报错,并告诉你应前往的redis实例地址和端口

  4.不在一个插槽的键值,不能使用mget、mset等多键操作;可以通过{}来定义组,使key{xxx}内相同的内容的键值对放到一个插槽中

  5.主节点宕机,从节点会自动变成主节点,主节点会变成从节点

  6.如果所有某一段插槽的主从节点都当掉,redis服务不能继续服务,因为这一段插槽不会自动分配到其他节点中去。

    redis.conf中参数 cluster-require-full-coverage  yes ;  默认16384个插槽全部正常时才工作

  7.相关命令

    CLUSTER KEYSLOT <key> 计算键 key 应该被放置在哪个槽上。

    CLUSTER COUNTKEYSINSLOT <slot> 返回槽 slot 目前包含的键值对数量。

    CLUSTER GETKEYSINSLOT <slot> <count> 返回 count 个 slot 槽中的键。

Redis---08Redis集群(一)的更多相关文章

  1. Redis分布式集群几点说道

    原文地址:http://www.cnblogs.com/verrion/p/redis_structure_type_selection.html  Redis分布式集群几点说道 Redis数据量日益 ...

  2. Redis集群(九):Redis Sharding集群Redis节点主从切换后客户端自动重新连接

    上文介绍了Redis Sharding集群的使用,点击阅读 本文介绍当某个Redis节点的Master节点发生问题,发生主从切换时,Jedis怎样自动重连新的Master节点 ​一.步骤如下: 1.配 ...

  3. Redis集群(八):Redis Sharding集群

    一.Redis目前的集群方案主要有两种:Redis Sharding和Redis Cluster 1.Redis Sharding:3.0以前基本上使用分片实现集群,目前主流方案,客户端实现 2.Re ...

  4. 170103、Redis官方集群方案 Redis Cluster

    前面我们谈了Redis Sharding多服务器集群技术,Redis Sharding是客户端Sharding技术,对于服务端来说,各个Redis服务器彼此是相互独立的,这对于服务端根据需要灵活部署R ...

  5. 【redis】 redis 创建集群时,Waiting for the cluster to join.... 一直等待

    redis 搭建集群时,一直join.... ./redis-trib.rb  create --replicas 1 127.0.0.1:6379 127.0.0.1:6380 127.0.0.1: ...

  6. Redis 一二事 - 在spring中使用jedis 连接调试单机redis以及集群redis

    Redis真是好,其中的键值用起来真心强大啊有木有, 之前的文章讲过搭建了redis集群 那么咋们该如何调用单机版的redis以及集群版的redis来使用缓存服务呢? 先讲讲单机版的,单机版redis ...

  7. 【Redis】Redis分布式集群几点说道

    Redis数据量日益增大,使用的公司越来越多,不仅用于做缓存,同时趋向于存储这一块,这样必促使集群的发展,各个公司也在收集适合自己的集群方案,目前行业用的比较多的是下面几种集群架构,大部分都是采用分片 ...

  8. nginx+tomcat+redis的集群+session共享

    nginx+tomcat+redis的集群+session共享 环境准备 1.tomcat版本:tomcat7 tomcat下载及安装,目前很多好的资源和步骤,此处省略. 2.jdk版本:jdk1.7 ...

  9. docker1.12 安装redis第三方集群方案 codis

    docker1.12 安装redis第三方集群方案 codis

  10. 02.Redis主从集群的Sentinel配置

    1.集群环境 1.Linux服务器列表 使用4台CentOS Linux服务器搭建环境,其IP地址如下: 192.168.110.100 192.168.110.101 192.168.110.102 ...

随机推荐

  1. Python爬取股票信息,并实现可视化数据

    前言 截止2019年年底我国股票投资者数量为15975.24万户, 如此多的股民热衷于炒股,首先抛开炒股技术不说, 那么多股票数据是不是非常难找, 找到之后是不是看着密密麻麻的数据是不是头都大了? 今 ...

  2. Combine 框架,从0到1 —— 5.Combine 中的 Subjects

    本文首发于 Ficow Shen's Blog,原文地址: Combine 框架,从0到1 -- 5.Combine 中的 Subjects. 内容概览 前言 PassthroughSubject C ...

  3. Jaskson精讲第7篇-类继承关系下的JSON序列化与反序列化JsonTypeInfo

    Jackson是Spring Boot(SpringBoot)默认的JSON数据处理框架,但是其并不依赖于任何的Spring 库.有的小伙伴以为Jackson只能在Spring框架内使用,其实不是的, ...

  4. Windows无法安装到GPT格式磁盘的根本解决办法 - 初学者系列 - 学习者系列文章

    上次在MSDN系统QQ群里有朋友问到在安装操作系统的时候有个问题:Windows无法安装到GPT格式磁盘,见图: 我在这里说下,使用网上方法的都是小白,就是说网上那些都是小白.下面介绍如何正确安装操作 ...

  5. js计算两个时间相差

    .filter('useTime', function() { return function(val) { // if (/.(.mp4)$/gi.test(url)) { // return JS ...

  6. Hbuilder给手机发送短信与拨打电话

    前言:业务场景 需要给手机号码拨打电话与发送短信.html5已经提供接口. methods: { Call: function() { var that = this; if(that.ptel == ...

  7. 获取豆瓣读书所有热门标签并保存到mongodb数据库

    目标url:https://book.douban.com/tag/?view=type&icn=index-sorttags-all 目的:抓取所有标签名称(tag_name),标签链接(t ...

  8. 安装、验证安装 Oracle Database XE 11gR2

    操作系统:Windows 10 x64 第一节:下载 Oracle Database XE 11gR2 第二节:安装.验证安装 Oracle Database XE 11gR2 第三节:Oracle ...

  9. 【题解】[USACO12JAN]Video Game G

    第一道\(AC\)自动机\(+DP.\) 首先,一个自动机上\(DP\)的套路是设\(dp[i][j]\)表示长度为\(i\)匹配到\(j\)节点的最优得分. 那么,由于我们已经建好了\(Trie\) ...

  10. 【MySQL Errors】Table 'xxx' is marked as crashed and should be repaired 的解决方案

    现象描述 访问 Zabbix Web,出现如下错误提示: • Error in query [SELECT * FROM history_uint h WHERE h.itemid='25067' O ...