写点什么

Vaughn Vernon 谈微服务和领域驱动设计

  • 2016-08-02
  • 本文字数:979 字

    阅读完需:约 3 分钟

虽然单体应用程序也可以实现相当好地建模,但它们常常会演变成一团乱麻。究其原因是单体应用程序内的多个领域模型错综复杂地交织在一起。根据 Vaughn Vernon 的经验,这种情况在几周或几个月内就会出现。在今年早些时候举行的 Scala Days 大会上,他在演讲中表达了这样的观点。

Vernon 是《实现领域驱动设计》和《通过Actor 模型实现响应式消息处理模式》这两本书的作者。他指出,当应该保持独立的领域模型混在了一起,互相无法区分时,就很难或者不可能和业务及领域专家一起从逻辑上推断模型,让应用或系统比单体应用程序还糟糕。

单体应用程序的一个替代方案是微服务,但我们如何定义一个微服务?它有多大?有时候,人们提出使用代码行定义微服务的大小,Vernon 见过以数十行为标准的,也见过一上千行为标准的,但他不主张采用这样一种既宽泛又不准确的定义。

此外,有些企业号称有数以百计的微服务,但又不知道或者不关心准确数值。他们认为,不值得花费时间和精力去弄清它们的实际使用情况,因为,只是让它们运行起来的话,成本会很低。Vernon 对此作出了回应。他不同意这样的观点。他指出,别的不说,基础设施对于许多微服务如何运行,如何在故障情况下保持弹性,有重大的影响。

Vernon 建议采用一种规定性的方法确定一个系统里微服务的大小和数量:使用领域驱动设计(DDD)的方法,尤其是有界上下文。他指出,在微服务社区里,有时候会将有界上下文定义成只有一个实体,但他发现那不大可能。相反,Vernon 支持借助通用语言在大小确定的有界上下文中建模微服务,并提到了Sam Newman 的著作《构建微服务》。

在开始使用微服务的时候,Vernon 建议从每个有界上下文一个微服务开始。他认为,即使我们能够在一个有界上下文中找出多个本身可以视为微服务的组件,但它们的内聚性和协同关系意味着它们应该一起放在一个服务里。他还建议,一个服务和一个有界上下文应该是一个可部署的单元。尽管如此,根据经验,他们可能会采用更细的粒度,为一个有界上下文创建更多的微服务和可部署单元,可能是因为扩展性方面的原因。

除了实体之外,通用语言还包括命令和事件消息。通过发布最终供其他微服务使用的事件,消息可以用在事件驱动的架构中。在演讲总结阶段,Vernon 展示了一个构建微服务的例子。该例子使用了 Actor 模型,并使用 Akka Scala 实现。

查看英文原文: Vaughn Vernon on Microservices and Domain-Driven Design

2016-08-02 19:003220
用户头像

发布了 1008 篇内容, 共 449.4 次阅读, 收获喜欢 346 次。

关注

评论

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

携手伊克罗德,国内知名会计师事务所借助Dify实现审计业务全链路升级

伊克罗德信息科技

“先导杯”上的三张面孔,照亮了国产AI生态的未来

Alter

AI 人才

精读GitHub - swift-markdown-ui

非专业程序员Ping

swift markdown SwiftUI ios 开发

C#/.NET/.NET Core技术前沿周刊 | 第 61 期(2025年11.10-11.16)

追逐时光者

.net

虚拟电厂VS传统电网:重新定义电力系统的运行逻辑

西格电力

能源革命 分布式云 新能源产业 虚拟电厂 虚拟电厂系统

阿尔特携手 Amazon AgentCore ,打造懂你的AI,智能搜索成本降低34%

亚马逊云科技 (Amazon Web Services)

人工智能

技术创新筑基 生态协同赋能——狄耐克深耕智慧场景书写高质量发展答卷

新消费日报

海量算力,一键配置!咕泡AI云实验室全面升级!

咕泡科技

咕泡ai 咕泡科技 实战平台

还在为搭建FAQ系统发愁?这10个问题帮你彻底搞懂知识库选型

百川云开发者

让老版IntelliJ IDEA 2020.1.4 支持JDK 17启动springboot3项目

JEECG低代码

入侵防护技术深度解析:最新漏洞与威胁态势

qife122

网络安全 漏洞分析 入侵防护

量化网络风险:持续DDoS测试的运营投资回报

qife122

DDoS测试 风险量化

MIAOYUN | 每周AI新鲜事儿(11.07-11.14)

MIAOYUN

人工智能 AI AIGC AI 大模型 AI工具推荐

2025十大数据资产管理平台排行榜:合规智能双驱,激活数据要素价值

科技经济

创新、开放、尊重,华为给出了知识产权保护的示范答卷

Alter

合力亿捷入选智能体客服第一梯队,成为行业头部代表厂商

极客天地

一个基于 .NET WPF 开源的本地硬盘千万级图库以图搜图小工具!

追逐时光者

.net WPF

点量云流突破架构壁垒,实现全栈信创自主可控

点量实时云渲染

arm 实时云渲染 云流化 国产信创 国产GPU

今日热门信息 - jobleap4u.com - 2025-11-17

Y11

求职 找工作 实习 校招

BeeWorks:更懂工作的企业级安全通讯平台

BeeWorks

即时通讯 IM 私有化部署

深入探索剖析 JVM 的启动过程

程序猿DD

Java

移动银行安全测试的11个最佳实践

qife122

移动安全 安全测试

大数据-155 Apache Druid 存储与查询架构实战:Segment/Chunk/Roll-up/Bitmap 一文讲清

武子康

Java 大数据 分布式 Druid Apache Druid

10 分钟搞定全栈无人机系统

俞凡

低空经济

Vaughn Vernon谈微服务和领域驱动设计_语言 & 开发_Jan Stenberg_InfoQ精选文章