阿里、蚂蚁、晟腾、中科加禾精彩分享 AI 基础设施洞见,现购票可享受 9 折优惠 |AICon 了解详情
写点什么

微服务和模块化

  • 2017-06-01
  • 本文字数:1490 字

    阅读完需:约 5 分钟

正如近一年以来在“微服务专题”中所讨论的,有多种原因促使开发人员选择微服务,也存在多个理由让开发人员避免使用微服务。最近, Gene Hughson 针对作家 Simon Brown 所提出的一个观点撰写了一篇文章,指出模块化的改进可能并非一个选择微服务的原因

在文中,Hughson 提出:

我相信,如果无法正确地构建单体应用(Monolith),那么这时试图强制采用分布式架构进行模块化,这实际上可能会导致损害。

事实上,对此问题 InfoQ 曾在 2014 年进行过一次讨论,其中 Brown 和 Hughson 探讨了微服务以及“大杂烩”(Big Ball of Mud)这一比喻。当时 Brown 给出了这样的说法:

如果你正在构建的单体应用系统已成了一个大杂烩,或许你应该思考一下,你是否对软件架构给予了足够的关注?你是否真正地理解了什么是软件中的核心结构抽象?软件的接口和职责是否清晰?如果你没有做到这些,那么为什么认为如果能迁移到微服务架构就会有所裨益?当然,对服务做物理分隔会强制性地规避一些捷径。但是在单体应用中,也可以实现同样的组件间分隔。

Hughson 将使用微服务做构建比作为冰山,一眼看上去所显现出来的部分,要远小于位于水下的部分:

如果一个开发团队不能或是不愿意去遵循设计的指导原则(例如,模块化需求),这时额外地添加复杂性可能并非是所需的解决方案。将应用分布化,会使应用更不易于“意外地”纠缠于各种关注中,但并不会杜绝该问题的发生。

Gene 借助于 Brown 的另一篇推文对最后一点做了说明:

Hughson 进而返回到对开发团队不能或是不愿意遵循设计指导原则的评论上,他继续指出:

我的观点是,增加“意外地”破坏模块化的困难度并不会解决前面提及的两组人员所面对的问题,即不能遵循设计指导原则的开发团队,以及不愿意遵循设计指导原则的开发团队。这颇具讽刺意味,那些并没有理解模块化必要性的人,可能无论各种障碍都会在他们的“解决方案”中颇具创造性。同理,对那些不愿意采用模块化的人同样适用。

Hughson 提出,分布式(微服务天生就是分布式的)作为一种实现模块化的手段,并不适用于目标。他认为,关注不应局限于应用架构上,也应同样地适用于应用数据。

一个具有纪律的单体应用团队,可以在单体应用数据架构中维护模块化。而试图共享一个单体应用数据架构的多个独立团队,可能会遇到严重的治理开销问题,也可能会完全地破坏模块化。

Christian Posta 在去年就指出了为什么应用中的数据管理会成为迁移到微服务时的最难部分。 InfoQ 当时就对此进行了报道

要对一个相当复杂的企业领域构建微服务,我们需要找到该领域中不同职责间的界限。在每个界限上创建一个针对该职责设计的、并表示了该职责的领域模型。进而,每个界限的数据模型被同一界限的领域模型所驱动。使用 DDD 就可以发现这些界限,并对每个界限创建一个“受限场景”(bounded context),这样每个场景可转变为一个微服务。

该文章的一条评论指出,这可能会需要一定形式的治理。对此,Hughson 持赞同态度:

消极措施不足以解决问题,无论是结构性的(“让我们将组件分布化,以免人们破坏模块性”)还是过程性的(例如,“要有纪律”)。治理在应用层(在我看来,即应用架构原则)及以上层是完全有必要的,它有助于实现对竞争利益的协调,并监督设计以免在黑暗的小巷中徘徊。请记住,这可能是由于误解、缺乏经验、不符合规范甚至设计不一致而导致的。需要有人监控所发生的情况,以及同样重要的发生原因。

总而言之,在 Hughson 看来,构建需要独立管理、扩展和部署组件的应用时,微服务的确可以发挥自身的作用。理解到这一点是很重要的。但是,也需要很好地理解为什么要选取沿微服务这条路走下去。

查看英文原文 Microservices and Modularity

2017-06-01 19:005940
用户头像

发布了 227 篇内容, 共 71.3 次阅读, 收获喜欢 27 次。

关注

评论

发布
暂无评论
发现更多内容

选择困难症的我,最终选择了Amazon EC2 云服务器

不叫猫先生

云服务器 Amazon EC2 云服务器

软件测试|带你了解Python正则表达式模块(一)

霍格沃兹测试开发学社

苹果Mac强大的远程管理工具:Royal TSX for Mac激活版 支持M1

彩云

Royal TSX 远程连接管理

亚马逊云服务器成了我的首选服务器

StackOverflow

云服务器 亚马逊云

3款免费又好用的 Docker 可视化管理工具

快乐非自愿限量之名

Docker 分享 教程 免费

融云荣登「2023 年度 PaaS 企业排行榜」

融云 RongCloud

互联网 PaaS 通信 企业 即时通讯

高效节省IT资源,WorkPlus让企业轻松实现业务场景的快速移动化

WorkPlus

潮玩宇宙APP系统开发

薇電13242772558

NFT

FomePay 充值 ChatGPT Plus 详细教程

月满楼

ChatGPT ChatGPT4 chatgpt app chatgpt api

2024上海国际大数据产业展览会(世亚智博会)

AIOTE智博会

大数据展览会 大数据展会 大数据博览会 大数据展

理论+实践详解最热的LLM应用框架LangChain

华为云开发者联盟

人工智能 华为云 华为云ModelArts 华为云开发者联盟 LLM

罗拉ROLA-IP代理IP:稳定性、纯净性、响应速度的保证

Geek_bf375d

软件测试|教你使用Python实现五子棋游戏(一)

霍格沃兹测试开发学社

软件测试|matplotlib中文不显示的解决方案

霍格沃兹测试开发学社

软件测试|Python绘图神器matplotlib教程(三)

霍格沃兹测试开发学社

调用API接口获取淘宝关键词商品数据:详细指南与代码实践

Noah

Util应用框架快速入门(二)- Web Api 快速入门

何镇汐

开源 后端 软件开发

在 LangChain 尝试了 N 种可能后,我发现了分块的奥义!

Zilliz

Milvus langchain rag chunking

一般的仿真软件需要什么配置的电脑?

思茂信息

仿真软件 仿真技术 仿真建模 仿真模拟

一文吃透Redis主从复制的原理

这我可不懂

redis

全面解析独立服务器:如何选择最适合你的方案?

一只扑棱蛾子

独立服务器

软件测试|教你使用Python快速绘制酷炫词云图

霍格沃兹测试开发学社

软件测试|教你用Python操作Word文档(二)

霍格沃兹测试开发学社

软件测试/校招推荐丨鼎捷软件股份有限公司岗位开放

测试人

软件测试

如何规划并新建大数据平台的独立生产域?5步走

奇点云

奇点云 DataSimba 对象体系

软件测试|Python数据可视化神器——pyecharts教程(四)

霍格沃兹测试开发学社

软件测试|一文教你学会Python文件 I/O 操作

霍格沃兹测试开发学社

轻量应用服务器到底香在哪?

格致君的planB

数字化 亚马逊云科技 轻量应用服务器

软件测试|教你用Python 操作Word文档(一)

霍格沃兹测试开发学社

Util应用框架快速入门(三)- UI 快速入门

何镇汐

开源 后端 开发软件

软件测试|Python matplotlib教程(二)

霍格沃兹测试开发学社

微服务和模块化_DevOps & 平台工程_Mark Little_InfoQ精选文章