写点什么

实体服务是一种反模式

2018 年 1 月 02 日

在微服务架构中,最重要的是要保持服务间的隔离。实体服务( 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 年 1 月 02 日 18:0011044
用户头像

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

关注

评论

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

架构师0期Week11作业2

Nan Jiang

USDT承兑商系统开发,USDT支付系统软件搭建

13530558032

解码微盟半年财报:同比增长59.9%,SaaS商业版图不断扩大

ToB行业头条

SaaS 微盟

高可用注意点

dony.zhang

高可用 高可用系统的架构 高可用系统的运维

作为程序员,推荐5种编程语言!

代码制造者

Python 编程语言 低代码 C语言 零代码

针对目前在线教育存在问题的解决方案

anyRTC开发者

WebRTC 在线教育 直播 安卓

程序员不得不知的软技能

flyer0126

软技能

一款JAVA快速开发平台,多项目整合,给开发提提速

力软.net/java开发平台

「Java 25周年」 工具软件 平台应用服务

架构师0期Week11作业1

Nan Jiang

java 是什么?作用是什么?

InfoQ_34a83d636158

一个用户秘密加密验证功能

elfkingw

熔断、限流的一些理解

elfkingw

30万奖金等你拿!Apache Flink 极客挑战赛入门指南(附Demo)

Apache Flink

flink

调度选得好,下班回家早

易观大数据

深圳数字货币交易所开发商,币币撮合交易软件开发

13530558032

XSKY S3 Console 为对象存储系统赋能

XSKY融合存储

账户经常被盗号怎么办?防盗“黑科技”了解一下

华为云开发者社区

华为云 云安全 主机安全 双因子认证 弱密码

Grabana:使用 Golang 或 Yaml 生成 Grafana Dashboard

郭旭东

go golang Grafana

java安全编码指南之:基础篇

力软.net/java开发平台

知乎李大海与阿里云贾扬清联合直播,AI大咖眼中的行业前景

InfoQ_967a83c6d0d7

源码解析 | 万字长文详解 Flink 中的 CopyOnWriteStateTable

Apache Flink

flink

力扣1514——概率最大的路径

健健

算法 最短路径

Week11

丿淡忘

架构训练营第十一周感悟

张锐

IDEA插件之Mybatis Log plugin破解!!!

不才陈某

Java idea插件

架构训练营第十一周作业

张锐

区块链钱包系统开发服务商,区块链钱包应用搭建

13530558032

安全&高可用架构

dony.zhang

高可用 安全 安全架构 高可用系统的架构 高可用系统的运维

Lambda架构已死,去ETL化的IOTA才是未来

易观大数据

安全及高可用策略

Lane

极客大学架构师训练营

合约跟单APP开发模式,合约跟单系统源码搭建

13530558032

NLP领域的2020年大事记及2021展望

NLP领域的2020年大事记及2021展望

实体服务是一种反模式-InfoQ