一、Redis Cluster集群简介

Redis Cluster是Redis官方提供的分布式解决方案,在3.0版本后推出的,有效地解决了Redis分布式的需求,当一个节点挂了可以快速的切换到另一个节点,当遇到单机内存、并发等瓶颈时,可以采用分布式方案要解决问题。

二、集群原理

Redis Cluster架构图

Redis Cluster集群采用了P2P的模式,完全去中心化,Redis把所有的Key分成了16384个slot,每个Redis实例负责其中一部分slot,集群中的所有信息(节点、端口、slot等),都通过节点之间定期的数据交换而更新,Redis客户端可以在任意一个Redis实例发出请求,如果所需数据不在该实例中,通过重定向命令引导客户端访问所需的实例。

其结构特点:所有的redis节点彼此互联(PING-PONG机制),内部使用二进制协议优化传输速度和带宽。

节点的fail是通过集群中超过半数的节点检测失效时才生效。

客户端与redis节点直连,不需要中间proxy层.客户端不需要连接集群所有节点,连接集群中任何一个可用节点即可。

redis-cluster把所有的物理节点映射到[0-16383]slot上(不一定是平均分配),cluster负责维护nodeslotvalue。

Redis集群预分好16384个桶,当需要在Redis集群中放置一个key-value 时,根据CRC16(key) mod 16384的值,决定将一个key放到哪个桶中。

三、集群搭建

要让集群正常工作至少需要3个主节点,一共就需要6个节点,其中3个为主节点,3个为从节点,为了简单在下面在一台机器上演示,演示使用了linux服务器上7000到7005的6个端口。下载redis、解压、安装wget http://download.redis.io/releases/redis-3.2.4.tar.gz

tar -zxvf redis-3.2.4.tar.gz

cd redis-3.2.4/

make && make install将redis-trib.rb复制到/usr/local/bin目录下cd src

cp redis-trib.rb /usr/local/bin创建Redis节点并修改配置文件mkdir redis_cluster

cd redis_cluster/

mkdir 7000 7001 7002 7003 7004 7005

cp redis.conf redis_cluster/7000

cp redis.conf redis_cluster/7001

cp redis.conf redis_cluster/7002

cp redis.conf redis_cluster/7003

cp redis.conf redis_cluster/7004

cp redis.conf redis_cluster/7005

按下面提示修改6个配置文件port  7000       //端口7000,7001,7002...

bind 本机ip       //默认ip为127.0.0.1 需要改为其他节点机器可访问的ip 否则创建集群时无法访问对应的端口,无法创建集群

daemonize    yes       //redis后台运行

pidfile  /var/run/redis_7000.pid    //pidfile文件对应7000,7001,7002

cluster-enabled  yes    //开启集群  把注释#去掉

cluster-config-file nodes.conf   //集群的配置  配置文件首次启动自动生成

cluster-node-timeout  15000     //请求超时  默认15秒,可自行设置

appendonly  yes         //aof日志开启  有需要就开启,它会每次写操作都记录一条日志

dir /root/redis-3.2.4/redis_cluster/7000   //目录,端口7000,7001,7002... ,必须配置,否则无法启动启动6个Redis实例,并且要指定配置文件,这些配置文件分别在各自的子目录下面./src/redis-server redis_cluster/7000/redis.conf

./src/redis-server redis_cluster/7001/redis.conf

./src/redis-server redis_cluster/7002/redis.conf

./src/redis-server redis_cluster/7003/redis.conf

./src/redis-server redis_cluster/7004/redis.conf

./src/redis-server redis_cluster/7005/redis.conf安装rubyyum install ruby

yum install -y rubygems

gem install redis -v 3.2.2使用redis-trib.rb创建集群cd /usr/local/bin

./redis-trib.rb create --replicas 1 192.168.0.204:7000 192.168.0.204:7001 192.168.0.204:7002 192.168.0.204:7003 192.168.0.204:7004 192.168.0.204:7005

运行结果如下:

Redis Cluster启动成功截图

如果一切顺利,你会看到类似截图上的消息: [OK] All 16384 slots covered, 这说明Redis的Cluster集群环境搭建成功。简单解释一下这个命令:调用 ruby 命令来进行创建集群,--replicas 1 表示主从节点比例为 1:1,即一个主节点对应一个从节点;然后,默认给我们分配好了每个主节点和对应从节点服务,以及solt的大小,因为在Redis集群中有且仅有16383个solt,默认情况会给我们平均分配,当然你可以指定,后续的增减节点也可以重新分配。

M: 5237fa04bd793832b605d92ceb1d2f493da22e43 为主节点Id

S: b6b696c11bbffa8f9d4e6397ef4d27b0b54fea32 192.168.0.204:7003 replicates 5237fa04bd793832b605d92ceb1d2f493da22e43 从节点下对应主节点Id

目前来看,7000-7002 为主节点,7003-7005 为从节点,并向你确认是否同意这么配置,输入yes后,会开始集群创建。

四、验证集群通过Cluster Nodes命令和Cluster Info命令来看看集群效果./redis-cli -c  -h 192.168.0.204 -p 7001

cluster info

cluster nodes

运行结果如下:

运行成功截图

在集群上通过增加数据来测试集群效果

运行结果如下:

测试集群截图

两台服务器安装redis集群_Redis Cluster搭建高可用Redis服务器集群相关推荐

  1. Keepalived + LVS-DR搭建高可用Web服务器集群

    导航: Keepalived概述 LVS概述 编译安装keepalived 配置主调度器 双机热备 一.Keepalived概述 keepalived是一个类似于layer3, 4 & 5交换 ...

  2. MyCAT+MySQL 搭建高可用企业级数据库集群

    第1章 课程介绍 课程介绍 1-1 MyCAT导学 试看 1-2 课程介绍 第2章 MyCAT入门 这一章中,我们将回顾了垂直切分,水平切分,分库分表等基础概念,然后快速回如何安装和启动MyCAT的, ...

  3. win2012故障转移mysql集群_Windows 2012 系统搭建高可用故障转移集群

    Windows 2012 系统搭建高可用故障转移集群 一.故障转移集群介绍 1.1系统介绍 故障转移群集是针对具有长期运行的内存中状态或具有大型的.频繁更新的数据状态的应用程序而设计.这些应用程序称为 ...

  4. 两台IB交换机使用server side方式做高可用的记录

    两台IB交换机使用server side方式做高可用的记录 额外注意:IB交换机也分可不可以管理,比如SX6036就是可以管理的IB交换机, 两台可以管理的IB交换机可以在IB交换机上配置高可用来实现 ...

  5. 如何搭建高可用Redis服务

    作者:漫步CODE人生 来自:cnblogs.com/scode2/p/8670980.html 题记 基于内存的Redis应该是目前各种web开发业务中最为常用的key-value数据库了,我们经常 ...

  6. 故障转移集群搭建高可用文件共享服务器

    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言 一.故障转移集群是什么? 二.什么是仲裁盘? 三.添加故障转移集群功能 四.故障转移集群的建立 五.配置集群仲裁盘 六 ...

  7. 搭建高可用的MongoDB集群(一):MongoDB的配置与副本集

    传统的关系数据库具有不错的性能及稳定性,同时,久经历史考验,许多优秀的数据库沉淀了下来,比如MySQL.然而随着数据体积的爆发性增长,数据类型的增多,许多传统关系数据库扩展难的特点也爆发了出来,NoS ...

  8. 使用Docker搭建高可用Mysql数据库集群

    文章目录 前言 正文 选择哪一种搭建集群的方式 PXC Replication 安装docker Docker操作的基本命令 安装PXC集群 负载均衡 双机热备 具体实现细节 安装keepalived ...

  9. 使用Docker-Compose搭建高可用redis哨兵集群

    头脑风暴 出于学习目的,您可以很轻松地在docker环境下运行redis的单个实例,但是如果您需要在生产环境中运行它,那么必须将Redis部署为HA(High Avaliable)模式. Redis ...

最新文章

  1. python判断密码是否正确_第一个python程序-判断登陆用户名和密码是否正确
  2. C#利用Graphics类绘制进阶--实现图片等比例缩放
  3. spark.mllib:NaiveBayes
  4. 异常(Exception )
  5. java 递归遍历对象所有属性_Java学习之Xml系列二:xml按条件查询、xml递归遍历所有元素和属性...
  6. linux网络配置命令 ifconfig 、route 、ip 、ip route
  7. fortran 读整行_我整周读过的最有趣的东西
  8. color-loss pytorch实现
  9. 计算机组成原理(三)--存储器的层次结构
  10. Enabled AWE
  11. OpenvSwitch readme faq
  12. Activity生命周期详解一
  13. 亲测window+iis+letsencrypt+ssl 手动续期(通配符域名)
  14. 2017美国数学建模MCM C题(大数据)翻译 “合作和导航”
  15. axure 抖音部件库_抖音常用工具和素材库大全
  16. android模拟win98中文版,Win98模拟器
  17. Auto CAD:CAD软件之顶层菜单栏(文件、编辑、视图、插入、格式、绘图、标注、修改、参数、窗口、数据视图)简介之详细攻略
  18. 120. Triangle(三角矩阵)
  19. 生病吃什么水果你知道吗?
  20. Vue+OpenLayers学习系列(九)Vue+OpenLayers小案例(长度测量、面积测量、坐标定位、坐标获取)

热门文章

  1. 吃西餐的吴大师略懂《赤壁》
  2. 安装APK失败,错误代码:INSTALL_FAILED_INVALID_APK 解决方案
  3. 连接Oracle远程数据库错误:ORA-12541,ORA-12514,ORA-01017的解决方法!
  4. CSS三角形如何工作?
  5. 如何在ImageView中缩放图像以保持纵横比
  6. Python是否具有字符串“包含”子字符串方法?
  7. 实用PS技巧分享,送给初入职场的你
  8. ES6 对象的新功能与解构赋值介绍
  9. 用MD5防止文件被写入恶意代码
  10. JS获取上传文件的大小