BT

如何利用碎片时间提升技术认知与能力? 点击获取答案

实体服务是一种反模式

| 作者 Jan Stenberg 关注 29 他的粉丝 ,译者 薛命灯 关注 23 他的粉丝 发布于 2018年1月3日. 估计阅读时间: 3 分钟 | GMTC大前端的下一站,PWA、Web框架、Node等最新最热的大前端话题邀你一起共同探讨。

在微服务架构中,最重要的是要保持服务间的隔离。实体服务(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

评价本文

专业度
风格

您好,朋友!

您需要 注册一个InfoQ账号 或者 才能进行评论。在您完成注册后还需要进行一些设置。

获得来自InfoQ的更多体验。

告诉我们您的想法

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

期待后续博文。 by gyb gyb

Entity Services确实是反模式。但是感觉用DDD的思想去拆分服务还是很难的,对团队要求很高。

Re: 期待后续博文。 by king clever

确实,特别是对于架构师的要求极高,国内大部分企业的架构师都还不具备这个能力

期待后续博文? by Liu Jack

怎么理解实体服务?1个微服务实例?

期待后续博文,学习解决之道 by Wei Alex

目前也遇到类似的困惑, 如何解决呢?! 期待中

Re: 期待后续博文。 by 王 啸

您的评论让我有感而发。一帮所谓架构师,今天看到一个新鲜东西,想想这东西高大上,好玩,怎么弄到项目上来,也不想想这东西到底应该咋用,发明的哥们是为了解决什么场景。仿佛今天发现了扳手这么个东西,觉得这东西比榔头轻巧,好东西,以后砸钉子就用他了。。。这帮哥们是怎么养成这么个毛病的呢?从小学开始,老师教一个知识点,讲完出一堆相关题型,往上套就对了,久而久之,先有知识点再套题就对了。

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

5 讨论

登陆InfoQ,与你最关心的话题互动。


找回密码....

Follow

关注你最喜爱的话题和作者

快速浏览网站内你所感兴趣话题的精选内容。

Like

内容自由定制

选择想要阅读的主题和喜爱的作者定制自己的新闻源。

Notifications

获取更新

设置通知机制以获取内容更新对您而言是否重要

BT