博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
实体服务是一种反模式
阅读量:6273 次
发布时间:2019-06-22

本文共 953 字,大约阅读时间需要 3 分钟。

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

\\

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

\\

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

\\

\\

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

\\

\\

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

\\

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

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

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

\\

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

\\

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

\\

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

\\

查看英文原文

转载地址:http://rglpa.baihongyu.com/

你可能感兴趣的文章
推荐一个非常好用的 MarkDown 编辑器!
查看>>
使用 Hooks 简化受控组件的状态绑定
查看>>
Canvas && CSS && SVG 三种实现仪表盘的方式
查看>>
简单易懂的谈谈 javascript 中的继承
查看>>
Spark学习之Spark 集群资源调度
查看>>
京东Taro:用技术解放小程序生产力 | 点评家
查看>>
Dart编程语言入门学习
查看>>
小程序登录逻辑
查看>>
vscode透明主题、霓虹灯字体
查看>>
多线程基础知识
查看>>
iOS汇编基础(四)指针和macho文件
查看>>
Laravel 技巧锦集
查看>>
Android 使用 ViewPager+RecyclerView+SmartRefreshLayout 实现顶部图片下拉视差效果
查看>>
Flutter之基础Widget
查看>>
写给0-3岁产品经理的12封信(第08篇)——产品运营能力
查看>>
ArcGIS Engine 符号自动化配置工具实现
查看>>
小程序 · 跳转带参数写法,兼容url的出错
查看>>
开源干货!!!.NET Core + Vue.js(iview-admin) 通用动态权限(RBAC)管理系统框架[DncZeus]开源啦!!!...
查看>>
flutter error
查看>>
Flask框架从入门到精通之模型数据库配置(十一)
查看>>