9折倒计时一周! QCon 全球软件开发大会·上海站讲师上线95% >>> 了解详情
写点什么

实体服务是一种反模式

  • 2018-01-02
  • 本文字数:935 字

    阅读完需:约 3 分钟

在微服务架构中,最重要的是要保持服务间的隔离。实体服务( Entity Service )是被广泛应用于微服务架构上的一种模式,但其实它是一种反模式,因为它背离了服务隔离的原则。 Michael Nygard 在他的微服务系列博客中提到了这一点。

Nygard 是“ Release It! ”的作者,他说实体服务被用于解决一个非常常见的问题,在微软的一本关于微服务架构的电子书中和Spring 的两个教程中均用到了这种模式。

在Nygard 看来,反模式只会让事情变得更糟。为了说明实体服务是一种反模式,他使用一个大型的遗留单体作为例子。这个应用程序有多个实例,每个实例都包含了所有特性:

根据Spring 的教程,使用微服务架构对这个应用程序进行重构,将特性分解到单独的服务中。但Nygard 说,大部分特性仍然需要多个实体,这样就会在多个实体之间形成依赖。比如,计算购物车的价钱需要所有服务的介入:

Nygard 认为,这些依赖会造成耦合,从而影响可用性、性能和容量。他还强调说,这些依赖导致语义上的耦合,一个服务的变更会波及到其他服务。在最糟糕的情况下,这样会导致一个服务需要与不同版本的服务打交道。

Nygard 总结了在微服务架构中使用实体服务将会产生的结果:

  • 团队仍然可以按照他们的节奏发布服务。
  • 语义上的耦合导致了跨团队的协商。
  • 大量请求需要调用实体服务,增加了流量负载。
  • 整体的可用性取决于更多的服务。

基于以上几点,Nygard 认为实体服务是一种反模式。

来自 Fourth.com 的首席架构师 Ben Morris 在另一篇博文中引用了 Nygard 的文章,他说,在微服务架构中使用实体服务比单体架构还要糟糕。Morris 认为,微服务的优势之一就是它的自治性,但细粒度的服务越多,它们之间的耦合就越大,从而降低了自治性。他强调说,流程的变更会变得很困难,因为困难涉及到大量的服务,而如果服务是由不同的开发团队进行维护的,那么变更会变得更加困难。使用大量小型耦合服务的另一个风险在于,一个服务发生故障会产生级联效应,影响到更多的服务。

Nygard 的博文引发了长时间的讨论。微软那本电子书的作者说,他们在书中已经针对使用 HTTP 调用来耦合微服务这样的做法提供了警告。他也强调,正确使用领域模型可以提升微服务的自治性。

在 Nygard 后续的博文中,他将会介绍实体服务的替代方案。

查看英文原文 Entity Services is an Antipattern

2018-01-02 18:0012541
用户头像

发布了 321 篇内容, 共 131.0 次阅读, 收获喜欢 139 次。

关注

评论

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

程序员的软件开发帮手,低代码当仁不让

互联网工科生

软件开发 低代码 JNPF

软件测试/人工智能|基于录制的接口测试用例自动生成技术探究

霍格沃兹测试开发学社

浅析漏洞可达技术及其运用

安势信息

漏洞检测 SCA工具 开源软件供应链安全 #漏洞挖掘 漏洞可达

Axure RP 9 9.0.0.3741中文授权

Geek_幻墨成诗

Axure RP 9 Axure RP 9汉化 Axure RP 9授权码 Axure RP 9破解版

工艺系统所管理数字化实践

明道云

app上架一直显示审核中状态要怎么处理?

AIGC虽好,但不要“贪杯”哦!

安势信息

SCA工具 AIGC 开源代码安全

什么是AI数字人,如何制作?

Geek_95debf

软件测试/人工智能|利用 EvoSuite 自动生成高质量的 Java 单元测试用例

霍格沃兹测试开发学社

解锁 ElasticJob 云原生实践的难题

不在线第一只蜗牛

分布式 云原生 Elastis

永久 Parallels Desktop 18 for mac 18.3.2激活版

Geek_幻墨成诗

Parallels Desktop 18

iThoughtsX for mac(思维导图工具) 9.4中文激活版

mac

思维导图软件 苹果mac Windows软件 iThoughtsX

论文开题报告怎么写?轻松掌握开题报告撰写攻略,附技术路线图模板!

彭宏豪95

流程图 大学生 在线白板 论文 绘图软件

DxO ViewPoint 4 直装激活版下载 支持M1 M2

iMac小白

Macos最好用的数据分析工具:Tableau Desktop 2019

彩云

数据分析工具 Tableau Desktop 2019

C#简化工作之实现网页爬虫获取数据

不在线第一只蜗牛

Java C# 开发 网络爬虫

数字人应用行业有哪些?

Geek_95debf

数字人对本地生活商家的影响和应用

Geek_95debf

如何降低API接口的使用成本和提高效率?

Geek_975207

API 文档

打造数字人偶像的意义与影响

Geek_95debf

单体架构、垂直应用架构、分布式、SOA、微服务之间有什么关系和区别

javaNice

Java 微服务

为什么要选择数字人SaaS系统源码独立部署呢?

Geek_95debf

苹果系列数据恢复软件Disk Drill for Mac 中文激活版下载

iMac小白

iStat Menus 6 for Mac 中文直装版下载 macOS系统监控软件

iMac小白

Photoshop 2024 for mac(ps2024最新)25.1中文激活版

Geek_幻墨成诗

Photoshop 2024破解版

Downie 4 for Mac(mac视频下载)4.6.34中文版

Geek_幻墨成诗

Downie 4 Mac版 Downie 4中文版 Downie mac破解版

存在即合理,低代码的探索之路

树上有只程序猿

软件开发 低代码 JNPF

springboot整合分页插件

javaNice

Java

软件测试/人工智能|使用 GraphWalker 实现自动化测试用例生成

霍格沃兹测试开发学社

鸿蒙开发已成新趋势

不在线第一只蜗牛

华为 鸿蒙 软件开发

mac清理强推:MacCleaner 3 Pro中文激活版下载

iMac小白

  • 扫码添加小助手
    领取最新资料包
实体服务是一种反模式_SOA_Jan Stenberg_InfoQ精选文章