前往小程序,Get更优阅读体验!
立即前往
发布
社区首页 >专栏 >高可用架构:fail-over的三种经典模式 | 架构师之路(10)

高可用架构:fail-over的三种经典模式 | 架构师之路(10)

作者头像
架构师之路
发布2024-12-24 12:58:03
发布2024-12-24 12:58:03
1690
举报
文章被收录于专栏:架构师之路架构师之路

《架构师之路:架构设计中的100个知识点》 10.故障转移fail-over的三种经典模式

前面的文章聊过,高可用的核心方法论是:冗余(replication) + 故障自动转移(fail-over)。

冗余很好理解,复制服务,复制数据。那故障转移有几种模式?

故障转移(fail-over)主要有三种模式。

其一:Active-Passive影子主模式。

在这种模式下,只有一个主节点(Active)在处理请求,另一个影子节点(Passive)则处于待命状态,准备在主节点故障时接管。

它的特点是,影子节点在主节点正常工作时并不参与工作,只有主节点发生故障时,影子节点才接管并参与负载。系统资源利用率最多只有50%。

无状态的服务,例如Nginx可以使用影子主模式保证高可用。

其二:Active-Active多活模式。

在这种模式下,所有节点均处于“活动”状态,平均处理负载,其优势是:

一,保证了高可用;

二,提升了吞吐量;

三,实施了负载均衡;

四,提高了资源利用效率;

但是,这类模式需要注意雪崩效应,少量节点挂掉的情况下,剩余节点能不能扛得住。

无状态的服务例如站点服务,微服务,可以采用这种高可用模式。

对于包含状态的服务,例如数据库,如果使用多活高可用。需要额外的机制来同步数据,并解决同步数据的过程中带来的数据冲突问题。对于大数据量高并发量的互联网业务最佳实践,一般不采用这种模式实施数据库的高可用,数据冲突问题根本搞不定。

那包含状态的服务,例如数据库,要怎么保证高可用?

其三:Hot-Standby热备模式。

热备份可以理解为影子模式的一种特例。

他的影子节点在平时也会工作,怎么工作呢?

影子节点只和主节点保持数据同步,但并不对外提供服务。

画外音:这里主要指写入服务,读服务不会变更数据状态,且不讨论。

这样,影子节点保持有最新的数据副本,在主节点挂掉后可以迅速接管,减少切换时间。并且影子节点在平时不对外提供服务,也不会有数据冲突。

在数据库这类存储状态,且需要快速恢复的场景,一般使用热备模式。

但需要注意的是,当主挂掉时,需要折衷一致性与可用性

1. 如果数据同步完成之前启动影子节点,数据可能会丢失,从而丧失最终一致;

2. 但如果等数据同步完成再启动影子节点,可能会等待一段时间,从而丧失可用性;

简单总结,fail-over三种常见模式:

(1)Active-Passive影子主模式,例如:NG;

(2)Active-Active多活模式,例如:web-server,service;

(3)Hot-Standby热备模式,例如:DB;

知其然,知其所以然。

思路比结论更重要。

补充阅读材料

讲透架构设计中的fail-over:

https://blog.alexewerlof.com/p/failover

5个章节,比我讲得更细:

1. fail-over的概念;

2. fail-over的核心原理;

3. fail-over的关键技术点;

4. fail-over的几种模式;

5. fail-over示例;

文章不长,10分钟读完。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2024-11-19,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 架构师之路 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档