【AICon】 如何构建高效的 RAG 系统?RAG 技术在实际应用中遇到的挑战及应对策略?>>> 了解详情
写点什么

实体服务是一种反模式

  • 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:0012814
用户头像

发布了 322 篇内容, 共 133.1 次阅读, 收获喜欢 142 次。

关注

评论

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

机器学习洞察 | 降本增效,无服务器推理是怎么做到的?

亚马逊云科技 (Amazon Web Services)

机器学习

千万级规模微服务稳定性技术揭秘:隔离策略

中原银行

微服务 云原生 稳定性治理

🎉号外号外!OpenTiny 将在HDC华为开发者大会正式发布!

Kagol

开源 前端 OpenTiny UI组件库

代码随想录Day10 - 栈与队列(上)

jjn0703

华为云Astro出品《低代码开发者101问》电子书上线

华为云PaaS服务小智

云计算 低代码 华为云

华为云CodeArts Build-云端化的编译构建平台

华为云PaaS服务小智

华为云 华为开发者大会2023

低代码开发,改变数字化游戏规则

伤感汤姆布利柏

宝塔面板Nginx开启Brotli压缩,提升网站加载速度-【给网站提提速】

百度搜索:蓝易云

Linux CDN 云服务器 压缩 宝塔面板

数智之潮下的移动生态: AI与低代码平台的完美交融!

不在线第一只蜗牛

移动应用 低代码 数智化 AI赋能

2023-07-07:给出两个字符串 str1 和 str2。 返回同时以 str1 和 str2 作为子序列的最短字符串。 如果答案不止一个,则可以返回满足条件的任意一个答案。 输入:str1 =

福大大架构师每日一题

Go 算法 rust 福大大架构师每日一题

阿里云通义大模型家族迎来新成员,通义万相已开启定向邀测~

新云力量

AI 2023人工智能大会 科技改变生活

阿里云AI绘画创作大模型通义万相亮相,已开启定向邀测!

新云力量

AI 2023人工智能大会 科技改变生活

解决CentOS yum源失效问题.

百度搜索:蓝易云

Linux centos 云服务器 香港VPS服务器 蓝易云

给大模型持久记忆!GitHub 2万星向量数据库云服务升级,国内云产品下周上线

Zilliz

云服务 Zilliz 向量数据库 zillizcloud

C++实现读写ini配置文件

攻城狮Wayne

跨功能需求(CFR)/ 非功能性需求(NFR)的目标设定

码猿外

技术管理 非功能性需求 跨功能需求

【文件管理】Linux系统-cp命令 – 复制文件或目录

百度搜索:蓝易云

Linux centos 服务器 云服务器 ECS

Linux系统使用cpulimit对CPU使用率进行限制

百度搜索:蓝易云

Linux 服务器 云服务器 蓝易云

引领AI浪潮:低代码开发平台点燃数智时代,释放人工智能的巨大潜力!

快乐非自愿限量之名

人工智能 低代码 AI赋能

iOS打包IPA教程

雪奈椰子

做大模型不要沉迷有趣,要解决企业问题

新云力量

AI 2023人工智能大会 科技改变生活

【文件管理】Linux系统-ls命令 – 显示指定工作目录下的文件及属性信息

百度搜索:蓝易云

Linux 服务器 云服务器 蓝易云 ls

Centos更新升级内核命令-以及区别.

百度搜索:蓝易云

Linux centos 云服务器

一文囊括Ceph所有利器(工具)

hs_wu

云计算 分布式存储 Ceph

OpsGPT 智能运维大语言模型业界首发

乘云 DataBuff

APM 可观测性 AIOPS Dynatrace Datadog

AI重塑千行百业 华为云发布盘古大模型3.0和昇腾AI云服务

华为云开发者联盟

人工智能 华为云 华为云开发者联盟 企业号 7 月 PK 榜

QEMU之CPU虚拟化(一):CPU虚拟化介绍

Linux内核拾遗

虚拟化 qemu kvm

【磁盘管理】fdisk命令 – 管理磁盘分区

百度搜索:蓝易云

Linux 命令 云服务器

软件测试 | 如何看Analysis分析图

测吧(北京)科技有限公司

测试

GeaFlow图计算快速上手之PageRank算法

TuGraphAnalytics

PageRank 图算法 图计算 图论 GeaFlow

实体服务是一种反模式_SOA_Jan Stenberg_InfoQ精选文章