当前位置:首页 > 科技  > 软件

单体架构、微服务和无服务器架构

来源: 责编: 时间:2024-01-19 17:27:08 364观看
导读前言在这篇文章中,我将演示在决定使用单体架构、微服务架构和无服务器架构时的权衡的简化心智模型。目标是突显每种风格的固有优势和缺陷,并提供关于何时选择哪种架构风格的指导。单体架构对于小团队或项目来说是理想的

前言

在这篇文章中,我将演示在决定使用单体架构、微服务架构和无服务器架构时的权衡的简化心智模型。目标是突显每种风格的固有优势和缺陷,并提供关于何时选择哪种架构风格的指导。tLT28资讯网——每日最新资讯28at.com

单体架构

对于小团队或项目来说是理想的入门架构。它简单易上手,通常在需要超过一个团队的规模之前能够提供很多收益。tLT28资讯网——每日最新资讯28at.com

在构建单体架构时,务必从模块化开始,即使可能会增加样板代码。这意味着构建组件并在层之间保持严格的逻辑分离(更多详见Clean Architecture)。tLT28资讯网——每日最新资讯28at.com

tLT28资讯网——每日最新资讯28at.com

  • 通信层 — 服务的外部接口
  • 封装 — 业务逻辑或用例的清晰接口
  • 领域实体 — 业务对象的数据表示,仅供内部使用
  • 架构隔离 — 避免实体之间的跨领域连接

优势

tLT28资讯网——每日最新资讯28at.com

•开发便利性 — 所有代码都在一起。•部署便利性 — 所有代码一起部署。•网络效率 — 所有计算发生在进程内。•成本共享效率 — 每台服务器上有大型共享的 CPU 和内存池。tLT28资讯网——每日最新资讯28at.com

权衡

tLT28资讯网——每日最新资讯28at.com

  • 组织规模的限制 — 由于开发、部署和代码的紧密耦合,需要协调的开销增加。
  • 技术债务的风险 — 容易采取捷径,构建紧密耦合的代码。

当您的团队看起来像上面的插图时,这表明您应该考虑演进您的架构到微服务。开发中的复杂性增加会高风险地降低质量,从而导致生产力减缓。这产生了一个矛盾的效果,即您雇佣的人越多,交付就变得越慢和不可预测。tLT28资讯网——每日最新资讯28at.com

微服务

对于业务需求开始增长并且团队分成多个团队时,这是理想的架构。这个里程碑自然地与将单体架构拆分成自然的、上下文边界的微服务相配合,以便团队可以更独立地扩展。tLT28资讯网——每日最新资讯28at.com

tLT28资讯网——每日最新资讯28at.com

设计你想要的组织,架构会追随着,踌躇着走来tLT28资讯网——每日最新资讯28at.com

我强烈建议采用Inverse Conway Maneuver策略,打破您的通信模式,否则促使单体的熟悉模式将继续像胶水一样将团队粘在一起。tLT28资讯网——每日最新资讯28at.com

优势

tLT28资讯网——每日最新资讯28at.com

  • 独立交付 — 减少依赖关系。
  • 明确所有权 — 实现强大的所有权模型。
  • 组织规模 — 促进团队间相对独立的并行努力。
  • 独立扩展 — 计算隔离允许平台的各部分独立扩展。

权衡

tLT28资讯网——每日最新资讯28at.com

  • 协调标准 — 标准的变化可能泄漏到架构中,降低一致性和整体可维护性。
  • 网络延迟惩罚 — 曾经在单个服务中共同存在的进程现在正在进行引入端到端计算的网络调用,引入了延迟。
  • 资源共享减少 — 曾经共享相同 CPU、内存和磁盘需求的进程现在部署有自己的专用资源。
  • 成本增加 — 与单体相比,每个服务的额外网络 I/O 和资源会导致额外的成本。

无服务器

对于不需要实时保证的某些工作负载来说,这是理想tLT28资讯网——每日最新资讯28at.com

的架构风格。异步、分布式处理,不要求代码始终保持热和立即可用。tLT28资讯网——每日最新资讯28at.com

tLT28资讯网——每日最新资讯28at.com

截至撰写本文时,该行业正在朝着编写更经济的系统的“绿色”方向发展,以减少我们计算的碳足迹。我认为这种架构风格是生态系统的一个强大补充,但并不能完全取代它的前辈的必要性。tLT28资讯网——每日最新资讯28at.com

优势

tLT28资讯网——每日最新资讯28at.com

  • 精益扩展 — 仅扩展所需的无服务器函数。
  • 成本效益 — 仅在需要时使用最少的资源部署资源。(警告:仅当计算是间歇性的时候。在计算需要保持热时,请查看下面的权衡。

权衡

tLT28资讯网——每日最新资讯28at.com

  • 资源效率惩罚 — 曾经共享相同 CPU、内存和磁盘需求的进程现在每个都有自己的最小要求。
  • 成本效益差 — 只有在部署时有恒定需求,使每个函数运行像热服务器时。
  • 网络惩罚 — 与单体和微服务相比,每个函数调用现在都是一个网络跳跃,而不是作为进程内计算共同存在。

随着时间的推移演进

那么,当您的业务或产品的需求不断增长时,您的架构演进可能是什么样子呢?tLT28资讯网——每日最新资讯28at.com


tLT28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-65366-0.html单体架构、微服务和无服务器架构

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Doris到底有多牛,为什么大厂都在使用它?

下一篇: 从 SQLlin 的更新看 Kotlin Multiplatform 技术更迭

标签:
  • 热门焦点
  • K60至尊版狂暴引擎2.0加持:超177万跑分斩获性能第一

    Redmi的后性能时代战略发布会今天下午如期举办,在本次发布会上,Redmi公布了多项关于和联发科的深度合作,以及新机K60 Ultra在软件和硬件方面的特性,例如:“K60 至尊版,双芯旗舰
  • 5月iOS设备好评榜:iPhone 14仅排第43?

    来到新的一月,安兔兔的各个榜单又重新汇总了数据,像安卓阵营的榜单都有着比较大的变动,不过iOS由于设备的更新换代并没有那么快,所以相对来说变化并不大,特别是iOS好评榜,老款设
  • CSS单标签实现转转logo

    转转品牌升级后更新了全新的Logo,今天我们用纯CSS来实现转转的新Logo,为了有一定的挑战性,这里我们只使用一个标签实现,将最大化的使用CSS能力完成Logo的绘制与动画效果。新logo
  • 自动化在DevOps中的力量:简化软件开发和交付

    自动化在DevOps中扮演着重要角色,它提升了DevOps的效能。通过自动化工具和方法,DevOps团队可以实现以下目标:消除手动和重复性任务。简化流程。在整个软件开发生命周期中实现更
  • 10天营收超1亿美元,《星铁》比《原神》差在哪?

    来源:伯虎财经作者:陈平安即便你没玩过《原神》,你一定听说过的它的大名。恨它的人把《原神》开服那天称作是中国游戏史上最黑暗的一天,有粉丝因为索尼在PS平台上线《原神》,怒而
  • 阿里大调整

    来源:产品刘有媒体报道称,近期淘宝天猫集团启动了近年来最大的人力制度改革,涉及员工绩效、层级体系等多个核心事项,目前已形成一个初步的“征求意见版”:1、取消P序列
  • 华为Mate 60系列用上可变灵动岛:正式版体验将会更出色

    这段时间以来,关于华为新旗舰的爆料日渐密集。据此前多方爆料,今年华为将开始恢复一年双旗舰战略,除上半年推出的P60系列外,往年下半年的Mate系列也将
  • 三星Galaxy Z Fold5今日亮相:厚度缩减但仍略显厚重

    据官方此前宣布,三星将于7月26日也就是今天在韩国首尔举办Unpacked活动,届时将带来带来包括Galaxy Buds 3、Galaxy Watch 6、Galaxy Tab S9、Galaxy
  • iQOO Neo8 Pro抢先上架:首发天玑9200+ 安卓性能之王

    经过了一段时间的密集爆料,昨日iQOO官方如期对外宣布:将于5月23日推出全新的iQOO Neo8系列新品,官方称这是一款拥有旗舰级性能调校的作品。随着发布时
Top