两台服务器安装redis集群_Redis Cluster搭建高可用Redis服务器集群
一、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服务器集群相关推荐
- Keepalived + LVS-DR搭建高可用Web服务器集群
导航: Keepalived概述 LVS概述 编译安装keepalived 配置主调度器 双机热备 一.Keepalived概述 keepalived是一个类似于layer3, 4 & 5交换 ...
- MyCAT+MySQL 搭建高可用企业级数据库集群
第1章 课程介绍 课程介绍 1-1 MyCAT导学 试看 1-2 课程介绍 第2章 MyCAT入门 这一章中,我们将回顾了垂直切分,水平切分,分库分表等基础概念,然后快速回如何安装和启动MyCAT的, ...
- win2012故障转移mysql集群_Windows 2012 系统搭建高可用故障转移集群
Windows 2012 系统搭建高可用故障转移集群 一.故障转移集群介绍 1.1系统介绍 故障转移群集是针对具有长期运行的内存中状态或具有大型的.频繁更新的数据状态的应用程序而设计.这些应用程序称为 ...
- 两台IB交换机使用server side方式做高可用的记录
两台IB交换机使用server side方式做高可用的记录 额外注意:IB交换机也分可不可以管理,比如SX6036就是可以管理的IB交换机, 两台可以管理的IB交换机可以在IB交换机上配置高可用来实现 ...
- 如何搭建高可用Redis服务
作者:漫步CODE人生 来自:cnblogs.com/scode2/p/8670980.html 题记 基于内存的Redis应该是目前各种web开发业务中最为常用的key-value数据库了,我们经常 ...
- 故障转移集群搭建高可用文件共享服务器
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言 一.故障转移集群是什么? 二.什么是仲裁盘? 三.添加故障转移集群功能 四.故障转移集群的建立 五.配置集群仲裁盘 六 ...
- 搭建高可用的MongoDB集群(一):MongoDB的配置与副本集
传统的关系数据库具有不错的性能及稳定性,同时,久经历史考验,许多优秀的数据库沉淀了下来,比如MySQL.然而随着数据体积的爆发性增长,数据类型的增多,许多传统关系数据库扩展难的特点也爆发了出来,NoS ...
- 使用Docker搭建高可用Mysql数据库集群
文章目录 前言 正文 选择哪一种搭建集群的方式 PXC Replication 安装docker Docker操作的基本命令 安装PXC集群 负载均衡 双机热备 具体实现细节 安装keepalived ...
- 使用Docker-Compose搭建高可用redis哨兵集群
头脑风暴 出于学习目的,您可以很轻松地在docker环境下运行redis的单个实例,但是如果您需要在生产环境中运行它,那么必须将Redis部署为HA(High Avaliable)模式. Redis ...
最新文章
- python判断密码是否正确_第一个python程序-判断登陆用户名和密码是否正确
- C#利用Graphics类绘制进阶--实现图片等比例缩放
- spark.mllib:NaiveBayes
- 异常(Exception )
- java 递归遍历对象所有属性_Java学习之Xml系列二:xml按条件查询、xml递归遍历所有元素和属性...
- linux网络配置命令 ifconfig 、route 、ip 、ip route
- fortran 读整行_我整周读过的最有趣的东西
- color-loss pytorch实现
- 计算机组成原理(三)--存储器的层次结构
- Enabled AWE
- OpenvSwitch readme faq
- Activity生命周期详解一
- 亲测window+iis+letsencrypt+ssl 手动续期(通配符域名)
- 2017美国数学建模MCM C题(大数据)翻译 “合作和导航”
- axure 抖音部件库_抖音常用工具和素材库大全
- android模拟win98中文版,Win98模拟器
- Auto CAD:CAD软件之顶层菜单栏(文件、编辑、视图、插入、格式、绘图、标注、修改、参数、窗口、数据视图)简介之详细攻略
- 120. Triangle(三角矩阵)
- 生病吃什么水果你知道吗?
- Vue+OpenLayers学习系列(九)Vue+OpenLayers小案例(长度测量、面积测量、坐标定位、坐标获取)