Redis 集群搭建(基于Linux)
一、基础环境
1.虚拟机 VMware 15.x
2.Linux系统,用的是Centos7的Linux系统
3.Redis数据库版本 5.0.3
二、Redis集群简介
1.背景
Redis在3.0版本前只支持单实例模式,虽然支持主从模式部署来解决单点的故障,但是现在互联网企业的数据,都是几百G的数据,完全无法满足业务的需求,所以,在3.0版本以后就退出了集群模式。
2.概念
将多台Redis的服务器组成集群,分担负载。相对于主从架构,是进一步的扩展和升级。集群中的多台主服务器,同时对外提供读写功能,并分担整体的负载压力。而且每台主服务器都还会有自己的从服务器,作为数据的副本,也作为各自主服务器的候补(当主服务器意为崩溃,则从服务器自动变为主服务器,保证了整个集群的高可用性)
在负载压力分担,和系统的高可用性上,集群是一个很好的解决方案。
三、集群的搭建
1.为了我们方便的搭建集群,我们需要建立一个目录,里面放着六台服务器(一个集群至少六台服务器)。如下:

我们自己建立了一个叫 redis-cluster 的目录(图中蓝色框),在这个目录中又建立了六个子目录,用来存放Redis服务器。
2.然后cd到我们原有的redis服务目录下,进行集群的配置修改
① cluster-enabled yes 开启集群的支持
② cluster-config-file nodes.conf 记录每个节点的信息,保存到文件nodes.conf文件中
③ bind 0.0.0.0 开放ip访问权限


3.然后在我们已经搭建好的Redis服务目录下,将已经设置好的 redis.conf 分别复制到我们建立好的六个目录下。如下:

注:redis_conf 是我的redis服务的守护进程启动配置目录,里面放着启动进程的redis.conf配置文件,后面的我们上面的建立的目录的相对路径。
4.在复制好六个服务器之后,再去修改每个服务的配置文件中的端口号 ,这里我们分配了8001 --8006 端口 分别给这个六个服务器。如下,

注:然后依次去修改其余的五个,保证服务的端口各不相同即可。
5. 接着,以各自的配置启动redis服务
redis-server 8001/redis.conf
redis-server 8002/redis.conf
redis-server 8003/redis.conf
redis-server 8004/redis.conf
redis-server 8005/redis.conf
redis-server 8006/redis.conf
开启后的效果图,如下

6.创建Redis集群
语法:
redis-cli --cluster create 192.168.142.131:9001 192.168.142.131:9002 192.168.142.131:9003 192.168.142.131:9004 192.168.142.131:9005 192.168.142.131:9006 --cluster-replicas 1
解释: redis 客户端 集群 创建 。。。上面创建六个redis服务器的端口。。。 集群 一比一主从配置

然后我们输入 yes ,Redis 就会创建好集群,结果如下。

7.集群说明
--cluster-replicas 1 表示主从复制比例为 1:1,即一个主节点对应一个从节点;然后,默认给我们分配好了每个主节点和对应从节点服务器,以及 slot 的大小,
因为在 Redis 集群中有且仅有 16384 个 slot ,默认情况会给我们平均分配,当然你可以指定,后续的增减节点也可以重新分配。
查看集群信息:192.168.134.124:7003> cluster info(查看集群信息)或cluster nodes(查看节点列表)
集群搭建完毕,6个节点,3主,3从,只有主节点才拥有槽,并对外提供读写数据服务。注意至少有3个主节点才可以搭建集群,为每个主至少分配1个从,所以至少需要6个redis节点才可以形成集群。
8.槽
- redis cluster 默认分配了 16384 个slot,所有的主redis服务器,大概均分所有的槽
- 存/取值时 ,redis会根据key,计算一个介于 0 – 16383之间的数字,此数字即为当前数据的槽位置,通过槽位置,决定哪个redis主服务器来负责本次访问
Redis 集群会把数据存在一个master节点,然后在这个master和其对应的slave之间进行数据同步。当读取数据时,也根据一致性哈希算法到对应的master节点获取数据。
只有当一个master 挂掉之后,才会启动一个对应的slave节点,充当master。
需要注意的是:必须要3个或以上的主节点,否则在创建集群时会失败,并且当存活的主节点数小于总节点数的一半时,整个集群就无法提供服务了。
9.集群的特性或者优点
集群搭建后:
- 性能的进一步提升,可以在单位时间内,吞吐更多的请求
- 数据的存储节点,具有高可用性(集群有好的容错机制)
集群容错:
- 所有槽可以被覆盖时,则集群正常运行
- 如果16384个槽,不能被所有主机完整覆盖了,则集群宕机
四、集群中节点的操作
1.删除从节点

测试效果如下:

2.添加从节点
redis-cli --cluster add-node 192.168.134.124:7000 192.168.134.124:7001 --cluster-slave --cluster-master-id 4032891b648e76b2975e5bc701e9c8a52ad6f3dd
# 注意:加新节点之前 要清楚新节点中数据
# add-node: 后面的分别跟着新加入的slave和集群中任意一个节点
# cluster-slave:表示加入的是slave节点
# --cluster-master-id:表示slave对应的master的node ID


3.删除主节点
需要先进行重新分片:
redis-cli --cluster reshard 192.168.142.131:9001 #后面的ip和端口 起到定位的作用
回车执行该语句
①系统会提出问题 要分出多少个槽 5461
②系统接着提出问题 将这些槽 分给谁 回答 一个主服务器的id
③系统再问 从哪里获得这些槽 回答 一个主服务器的id
④接着执行done 和yes 开始重新分片

4.添加主节点
redis-cli --cluster add-node 192.168.134.124:7000 192.168.134.124:7006
#新增加的主节点 #一个已存在的节点 定位集群的作用
将7006添加到7001所在集群中,成为一个主节点,但此时它不持有任何槽,需要重新分片
具体操作图 如下,




之后输入done 即可执行分槽。
开始后,确认,系统问你要执行吗
输入yes

然后会执行一段时间的迁移过程

以上就是关于Redis集群的相关知识。
Redis 集群搭建(基于Linux)的更多相关文章
- Redis集群搭建方案(Linux)
Redis简介 redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串). list(链表).set(集合)和zset(有序 ...
- Linux Redis集群搭建与集群客户端实现(Python)
硬件环境 本文适用的硬件环境如下 Linux版本:CentOS release 6.7 (Final) Redis版本: Redis已经成功安装,安装路径为/home/idata/yangfan/lo ...
- Linux Redis集群搭建与集群客户端实现
硬件环境 本文适用的硬件环境如下 Linux版本:CentOS release 6.7 (Final) Redis版本: Redis已经成功安装,安装路径为/home/idata/yangfan/lo ...
- Redis集群环境之linux搭建多机版---已完结,跟着一步一步来你就可以集群成功
上一篇踩着各种坑写了Redis集群环境之linux搭建单机版,这一篇准备就多机版集群进行搭建,主要目的一来是在上一篇的基础上进行精华提粹总结,二来是把单机版与多机版的区别进行记录. 首先软硬件环境: ...
- 基于Dokcer搭建Redis集群搭建(主从集群)
最近陆陆续续有不少园友加我好友咨询 redis 集群搭建的问题,我觉得之前写的这篇 <基于Docker的Redis集群搭建> 文章一定是有问题了,所以我花了几分钟浏览之前的文章总结了下面几 ...
- Redis 集群搭建详细指南
先有鸡还是先有蛋? 最近有朋友问了一个问题,说毕业后去大城市还是小城市?去大公司还是小公司?我的回答都是大城市!大公司! 为什么这么说呢,你想一下,无论女孩男孩找朋友都喜欢找个子高胸大的.同样的道理嘛 ...
- redis集群搭建及注意事项
上一篇:redis的安装及注意事项 这里,在一个Linux虚拟机上搭建6个节点的redis伪集群,思路很简单,一台虚拟机上开启6个redis实例,每个redis实例有自己的端口.这样的话,相当于模拟出 ...
- Redis集群搭建 三主三从
Redis集群介绍 Redis 是一个开源的 key-value 存储系统,由于出众的性能,大部分互联网企业都用来做服务器端缓存.Redis在3.0版本之前只支持单实例模式 虽然支持主从模式,哨兵模式 ...
- 25.redis集群搭建笔记
###Redis集群### 0.准备 软件: redis-3.0.0.gem redis-3.0.0.tar.gz#源码 1.安装ruby环境 redis基于ruby槽位计算,hash算法技术,k ...
- 二、redis集群搭建
redis集群搭建 redis3.0后支持集群.集群中应该至少有三个节点,每个节点有一备份节点.需要6台服务器.搭建伪分布式,需要6个redis实例.搭建集群的步骤: 一.安装单机版redis 第一步 ...
随机推荐
- JavaScript之数学对象Math
Javascript 中Math和其他对象不同,它具有数学常数和函数的属性和方法.因为它的属性是数学常数,所以不能被改变(可以进行赋值操作,但最后值不变). Math的方法就是普通函数,调用他们直接用 ...
- Mysql学习笔记整理之索引
索引的概念: 索引是一个分散存储的数据结构(检索)对数据库表中一列或多列的值进行排序 为什么要用索引? 索引能极大的减少存储引擎需要扫描的数据量 索引可以把随机IO变成顺序IO 索引可以帮助我们进行分 ...
- SSM框架中测试单元的使用,spring整合Junit
测试类中的问题和解决思路 3.1.1 问题 在测试类中,每个测试方法都有以下两行代码: ApplicationContext ac = new ClassPathXmlApplicatio ...
- 微信小程序中scroll-view的几个坑
微信小程序中scroll-view的几个坑 1:设置scroll-x时,却不能横向滚动,因为view是block组件,但是这里用了flex就不能滚动了(想用flex布局,请开启属性enable-fle ...
- Spring Boot 的单元测试和集成测试
学习如何使用本教程中提供的工具,并在 Spring Boot 环境中编写单元测试和集成测试. 1. 概览 本文中,我们将了解如何编写单元测试并将其集成在 Spring Boot 环境中.你可在网上找到 ...
- Kafka 异步消息也会阻塞?记一次 Dubbo 频繁超时排查过程
线上某服务 A 调用服务 B 接口完成一次交易,一次晚上的生产变更之后,系统监控发现服务 B 接口频繁超时,后续甚至返回线程池耗尽错误 Thread pool is EXHAUSTED.因为服务 B ...
- Scala 异常处理
Scala 异常处理: parseURL("www.baidu.com") 会返回一个 Success[URL] ,包含了解析后的网址, 反之 parseULR("www ...
- Kafka 学习笔记之 删除Topic
删除Topic 1. 显示所有Topic信息,testTopic是我们将要删除的Topic 2. 首先确认server.properties下面配置是否已经加上delete.topic.enable= ...
- python编程基础之三十八
正则表达式:正则表达式是对字符串操作的一种逻辑公式,就是用事先定义好的一些特定字符.及这些特定字符的组合,组成一个“规则字符串”,这个“规则字符串”用来表达对字符串的一种过滤逻辑. 需要引入内置模块r ...
- 洛谷 P3745 [六省联考2017]期末考试
题目描述 有 nnn 位同学,每位同学都参加了全部的 mmm 门课程的期末考试,都在焦急的等待成绩的公布. 第 iii 位同学希望在第 tit_iti 天或之前得知所有课程的成绩.如果在第 tit_ ...