三种Resis 集群方案

为什么要redis集群?

Redis 集群是 Redis 分布式架构的一种实现方式,它可以将多个 Redis 节点组成一个集群,提供高可用、高吞吐量和负载均衡等特性

一. 主从复制模式

就是一主多从,redis会把机器节点分为主节点和从节点,主节点负责处理写入请求和数据同步,从节点负责从主节点同步数据,并提供读取服务。在 Redis 主从复制中

实现

Redis 主从复制的实现方式是将主节点的写入操作同步到从节点,从节点通过复制主节点的命令序列来同步数据。以下是 Redis 主从复制的实现步骤:

  • 配置文件:在主节点和从节点上分别配置相同的 redis.conf 配置文件,包括节点地址、端口、密码等配置信息。
  • 主节点配置:在主节点上开启数据同步功能,并配置允许从节点连接主节点。
  • 从节点配置:在从节点上配置连接主节点的地址和端口,并启动从节点。
  • 数据同步:主节点将写入的数据同步到从节点,从节点通过复制主节点的命令序列来同步数据。
  • 故障切换:当主节点宕机或失去连接时,从节点可以通过选举机制重新选举一个主节点。

优点

  1. 提高系统的可用性

通过主从复制技术,主节点的数据可以同步到从节点上,当主节点出现故障时,从节点可以接管主节点的工作,从而提高系统的可用性。

  1. 支持读写分离

通过主从复制技术,从节点可以负责读取服务,从而将读操作分散到多个从节点上,减轻主节点的负载压力,提高系统的性能。

  1. 提高数据的可靠性

通过主从复制技术,主节点的数据可以同步到多个从节点上,从而提高数据的可靠性和安全性。

  1. 支持在线扩容

通过主从复制技术,可以在线增加从节点,从而实现在线扩容,提高系统的可扩展性。

  1. 支持数据备份和恢复

哨兵模式(Sentinel

哨兵模式是一种特殊的模式,
当我们使用主从复制时出现故障时,我们需要手动改变主节点,这无疑很浪费时间。而Redis 哨兵模式是一种用于实现 Redis 高可用性的方案,它可以实现自动监控 Redis 主节点的健康状况,并在主节点宕机时自动将从节点晋升为新的主节点,从而实现 Redis 集群的高可用性

在哨兵模式下有三种节点

  • 哨兵节点(sentinel):Redis 哨兵模式中负责监控 Redis 节点的健康状况,当主节点宕机时,哨兵节点可以自动完成主从切换。
  • 主节点(master):Redis 哨兵模式中负责处理写入请求和数据同步的节点。
  • 从节点(slave):Redis 哨兵模式中负责从主节点同步数据,并提供读取服务的节点。

实现

  • 配置文件:在每个节点上配置相同的 sentinel.conf 配置文件,包括节点地址、端口、密码等配置信息。
  • 启动节点:启动每个节点的 Redis 和 Sentinel 进程,并使用 sentinel.conf 配置文件指定每个节点的角色和地址。
  • 哨兵监控:哨兵节点会周期性地检查 Redis 节点的状态,当主节点宕机时,哨兵节点会自动选举一个从节点作为新的主节点,并将其他从节点切换到新的主节点上。
  • 故障恢复:当主节点恢复时,哨兵节点会将从节点重新设置为主节点的从节点,并恢复数据同步。

Cluster 集群模式(Redis官方)

在之前两种集群方案,都不能做到负载均衡,而
Redis Cluster 是 Redis 的分布式集群方案,它可以将数据分散到多个节点上进行存储和处理,并实现数据的自动分片和负载均衡,从而提高系统的吞吐量和性能。

概念

  • 集群节点(node):Redis Cluster 中的每个节点都是一个集群节点,节点之间通过 Gossip 协议进行通信,实现数据的自动分片和负载均衡。

  • 插槽(slot):Redis Cluster 将数据分散到多个插槽中进行存储和处理,每个插槽包含一个数据分片,可以分配给不同的节点进行存储和处理。

  • 主节点(master):Redis Cluster 中负责处理写入请求和数据同步的节点。

  • 从节点(slave):Redis Cluster 中负责从主节点同步数据,并提供读取服务的节点。

数据分片

redis 集群使用16384个哈希槽,每个集群的节点负责一部分的hash槽,每个hash槽都有一部分数据

实现

Redis Cluster 的实现步骤:

  • 配置文件:在每个节点上配置相同的 redis.conf 配置文件,包括节点地址、端口、密码等配置信息。
  • 启动节点:启动每个节点的 Redis 进程,并使用 redis.conf 配置文件指定每个节点的角色和地址。
  • 创建集群:使用 redis-cli 工具创建 Redis Cluster 集群,并指定集群中的主节点和从节点。
  • 数据分片:将数据分散到多个插槽中进行存储和处理,每个插槽包含一个数据分片,可以分配给不同的节点进行存储和处理。
  • 故障处理:当节点宕机时,Redis Cluster 会通过 Gossip 协议进行自动故障检测和故障转移,将数据重新分配到其他节点上。

优点

  1. 高性能和吞吐量

Redis Cluster 可以将数据自动分散到多个节点上进行存储和处理,从而提高系统的吞吐量和性能。

  1. 自动分片和负载均衡

Redis Cluster 可以自动将数据分片到多个节点上进行存储和处理,并实现负载均衡,从而避免节点负载不均衡和数据热点问题。

  1. 高可用性和故障转移

Redis Cluster 可以实现主从复制和自动故障转移,当主节点宕机时,可以自动将数据重新分配到其他节点上,从而实现高可用性和故障转移。

  1. 易于扩展和管理

Redis Cluster 可以在线扩容和缩容,从而实现系统的动态扩展和管理,同时也可以通过 redis-cli 等工具进行集群管理和监控。

  1. 分布式事务支持

Redis Cluster 支持分布式事务,可以通过 MULTI 和 EXEC 等命令实现跨节点的事务处理。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
"res is not defined" 是一个常见的错误提示,意味着在代码中使用了一个未定义的变量 "res"。通常情况下,这个错误提示是由于变量名拼写错误或者变量未在所在作用域进行声明所致。 在你提供的引用中,和提供了一些关于正确使用变量 "res" 的示例。在使用wx.request方法时,可以通过success回调函数来获取响应数据,并将其赋值给变量 "res"。例如,你可以这样使用: wx.request({ url: 'https://www.tuziang.com/', data: { //传入的参数 }, success(res) { console.log(res.data) //这样使用res才不会错误 } }) 这样,当请求成功时,响应数据就会被保存在变量 "res" 中,你可以通过 res.data 来访问它。 另外,在中提到了一些链接和资源,但没有明确与错误 "res is not defined" 的关系。因此,我无法直接使用这些引用内容来回答你的问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [小程序 res is not defined;at “pages/index/index“ page](https://blog.csdn.net/qq_34626094/article/details/112401991)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [微信支付demo所需要用到的CryptoJS js大集合2014年最新](https://download.csdn.net/download/zhousir0055/7547603)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值