我的编程空间,编程开发者的网络收藏夹
学习永远不晚

详解redis集群的三种方式

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

详解redis集群的三种方式

Redis三种集群方式:主从复制,哨兵模式,Cluster集群。

主从复制

详解redis集群的三种方式

基本原理

当新建立一个从服务器时,从服务器将向主服务器发送SYNC命令,接收到SYNC命令后的主服务器会进行一次BGSAVE命令,在执行期间,会将所有命令写入缓冲区中,当BGSAVE命令执行完毕之后会将生成的RDB文件发送给从服务器,从服务器使用这个文件加载数据到内存中,之后主服务器会以Redis命令协议的格式将缓冲区的命令发送给从服务器。此后每次主服务执行命令都会同步给从服务器。即使有多个从服务器向主服务器发送SYNC命令,主服务器也只会执行一个BGSAVE命令,就可以处理接下来的同步请求。一个主服务器可以拥有多个从服务器,而从服务器也可拥有从服务器,从而形成一个图状结构,复制功能不会阻塞主服务器,即使有一个或多个同步请求,主服务器依然能处理命令请求。

持久化开关

当配置了主从复制模式时需要开启主服务器的持久化功能,如果将主服务器的持久化功能关闭,主服务器一旦重启,所有从服务器的数据将会丢失,即使配置了Sentinel模式,如果主服务器自动拉起进程比较快,以至于在Sentinel模式下还未选举出新的主服务器,主服务的启动也会造成子服务器的数据丢失。

配置

配置一个主从复制模式,只需要使用Slaveof命令即可,在conf配置文件中添加或者是在redis中执行命令。

SLAVEOF host port

哨兵模式

详解redis集群的三种方式

基本原理

Redis的Sentinel系统用于管理多个Redis,主要执行以下三件事:

监控:Sentinel会不断的检查主从服务器运行状态

提醒:当某个Redis服务器出现故障,可通过API或者其他应用程序发送通知

自动故障迁移:当一个主服务器不能正常工作时,Sentinel会进行一次故障自动迁移,会将失效主服务器的从服务器选举出一个新的主服务器,剩下的从服务器将会自动连接复制选举出来的新服务器的数据。

Redis的Sentinel系统是一个分布式的系统,可以在系统中配置一个或多个Sentinel。

启动

使用redis-sentinel启动

redis-sentinel sentinel.confy

也可以使用redis-server来启动

redis-server sentinel.conf --sentinelyy

以上两种方式都可以启动sentinel,启动sentinel必须指定配置文件,否则无法启动:

详解redis集群的三种方式

配置

一个sentinel.conf文件最少需要一句配置:

sentinel monitor mymaster 127.0.0.1 6379 2

监视一个别名叫做mymaster的主机,地址是127.0.0.1,端口是6379,将这个主服务器判断为失效至少需要2个sentinel同意。

无论设置多少个sentinel同意判断一个主服务器的失效,都需要系统中多个Sentinel支持才能进行故障迁移,而只有少数sentinel正常运行的时候,是无法进行故障迁移。

故障迁移

当一个Sentinel发现主服务器下线时,称为主观下线,只有多个Sentinel都发现主服务下线,并相互之间通过命令进行交流判断主服务器下线时,称为客观下线。只有对主服务器进行客观下线时,会选举出领头Sentinel,选举出之后,会进行新的主服务器投票选举,选举出一个从服务器升级为主服务器。并向被选中的从服务器发送Slaveof no one命令,让其变为主服务器,通过发布订阅的功能,将新的配置广播给其他Sentinel进行更新,并向下线的主服务器发送Slaveof命令,让其复制新的主服务器,当所有从服务器都已经开始复制新的主服务器时,领头Sentinel终止本次故障迁移。

当一个 Redis 实例被重新配置是,无论是被设置成主服务器、从服务器、又或者被设置成其他主服务器的从服务器 ,Sentinel 都会向被重新配置的实例发送一个 CONFIG REWRITE 命令, 从而确保这些配置会持久化在硬盘里。

Cluster集群

详解redis集群的三种方式

之前的主从复制,哨兵模式都难以再现扩容,而Redis cluster集群实现了对Redis的水平扩容,即启动N个Redis节点,每个节点又可以有自己的从服务器,将数据均匀分布的存储在这N个结点上,每个节点存储数据的1/N。Redis cluster集群就是一个可以在多个Redis节点之间进行数据共享的设施;Redis cluster集群采用的是无中心化配置,即节点A无法处理,会将请求转发只节点B进行处理。

键分布模型

Redis集群中的键空间被分割为16384个槽位。每个主节点负责16384中槽位的一部分,Redis使用CRC16 算法进行槽位分配。为了保证高可用,cluster模式也引入了主从复制模式,一个主节点对应一个或多个从节点,当主节点发生宕机时,可进行故障转移,将子节点升级为主节点。

配置cluster集群

Redis 集群由多个运行在集群模式(cluster mode)下的 Redis 实例组成, 实例的集群模式需要通过配置来开启,以下是一个包含了最少选项的集群配置文件示例:

port 7000
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout 5000
appendonly yes

cluster-enabled:打开集群模式
cluster-config-file:节点配置文件名,无须人为修改, 它由 Redis 集群在启动时创建, 并在有需要时自动进行更新
cluster-node-timeout:节点失联时间,当超过此毫秒,集群将自动切换主从节点。

要让集群正常运作至少需要三个主节点,而每个主节点都应该正确配置一个或者多个从节点。

启动集群

使用redis-cli --cluster create命令将节点合并成一个集群

redis-cli --cluster create --cluster-replicas 1  127.0.0.1:7000 127.0.0.1:7001 127.0.0.1:7002 127.0.0.1:7003 127.0.0.1:7004 127.0.0.1:7005

 --cluster-replicas 1 这个指的是从机的数量,表示我们希望为集群中的每个主节点创建一个从节点。

进入集群模式只需要使用redis-cli -c命令

redis-cli -c -p 7000

无中心话节点,所以进入任意一个端口号的主节点即可。

到此这篇关于redis集群的三种方式的文章就介绍到这了,更多相关redis集群内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

详解redis集群的三种方式

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

详解redis集群的三种方式

目录主从复制基本原理持久化开关配置哨兵模式基本原理启动配置故障迁移Cluster集群键分布模型配置cluster集群启动集群Redis三种集群方式:主从复制,哨兵模式,Cluster集群。主从复制基本原理当新建立一个从服务器时,从服务器
2022-07-25

一文带你了解Redis的三种集群模式

目录Redis 的三种集群模式主从复制模式哨兵模式Redis-Cluster集群模式小结Redis 的三种集群模式Redis 的常用的集群方式主要有以下三种,分别是主从复制模式、哨兵模式、Redis-Cluster集群模式,那么下面我们就
2023-06-10

一文掌握Redis的三种集群方案

在开发测试环境中,我们一般搭建Redis的单实例来应对开发测试需求,但是在生产环境,如果对可用性、可靠性要求较高,则需要引入Redis的集群方案。虽然现在各大云平台有提供缓存服务可以直接使用,但了解一下其背后的实现与原理总还是有些必要(比如面试), 本文就一起
一文掌握Redis的三种集群方案
2021-08-29

详解Spring Boot 访问Redis的三种方式

目录前言开始准备RedisTemplateJPA RepositoryCache总结前言最近在极客时间上面学习丁雪丰老师的《玩转 Spring 全家桶》,其中讲到访问Redis的方式,我专门把他们抽出来,在一起对比下,体验一下三种方式开发
2022-12-13

详解Spring Boot 访问Redis的三种方式

这篇文章主要介绍了Spring Boot 访问Redis的三种方式,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2022-12-14

mysql备份的三种方式详解

备份的本质就是将数据集另存一个副本,但是原数据会不停的发生变化,所以利用备份只能回复到数据变化之前的数据。那变化之后的呢?所以制定一个好的备份策略很重要
2022-11-15

详细阐述交换机的三种连接方式:级联、堆叠和集群

我们都知道,工业交换机的连接方式一般有这3种:级联、堆叠和集群。但是很多朋友对这3种连接方式了解的不是很全面。所以今天我们就详细介绍一下这3种连接方式和它们之间的区别! 交换机的级联技术一般用来实现多台交换机之间的互相连
2023-06-05

详解mybatis三种分页方式

本文主要介绍了详解mybatis三种分页方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2022-11-13

Redis集群搭建的方式有哪些

这篇文章主要介绍Redis集群搭建的方式有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、单节点实例单节点实例还是比较简单的,平时做个测试,写个小程序如果需要用到缓存的话,启动一个Redis 还是很轻松的,做为
2023-06-15

redis集群切片的方式有哪些

在Redis集群中,数据的切片方式通常有以下几种:哈希切片:根据数据的键值进行哈希计算,然后将数据分布到不同的节点上。这种切片方式可以确保数据在节点之间均匀分布,但可能会导致某些节点负载过重。范围切片:将数据按照一定的范围进行切片,例如按照
redis集群切片的方式有哪些
2024-04-09

redis加锁的三种方式小结

本文主要介绍了redis加锁的三种方式小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-01-04

编程热搜

目录