硬核干货——《中小企业 AI 实战指南》免费下载! 了解详情
写点什么

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

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

关注

评论

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

中国云计算的云栖“坐标”

脑极体

随想之乐观估计

云杉

架构师课程大作业 知识图谱

杉松壁

甲方日常 14

句子

Java 工作 随笔杂谈 日常

欧洲央行近期将决定是否建立官方数字货币

CECBC

数字货币 欧央行

Spring 5 中文解析测试篇-WebTestClient

青年IT男

单元测试 Spring5

测试

云龙

C/C++基础之sizeof使用

C语言与CPP编程

c c++ 编程 编程语言

非科班进大厂必备算法

我是程序员小贱

面试 算法

STL总结与常见面试题

C语言与CPP编程

c c++ 编程 编程语言 stl

组合模式

纯纯

SpringBoot RabbitMQ消息队列的重试、超时、延时、死信队列

Barry的异想世界

RabbitMQ springboot 消息队列 死信队列 延时队列

大作业

Geek_2e7dd7

高并发系列——CAS操作及CPU底层操作解析

诸葛小猿

CAS AtomicInteger compareAndSwap cmpxchg lock

前端必会的七种排序算法

执鸢者

算法 大前端

Spring事务是如何应用到你的业务场景中的?

AI乔治

Java spring 架构 微服务 springboot

你需要开始做点什么,否则你会一直忙一直忙

老胡爱分享

学习 思维方式 行动派 随笔杂谈 拖延症

2020英特尔大师挑战赛携手华硕ROG激战成都

E科讯

测试

解决分布式session问题

架构师修行之路

分布式 架构设计 session

你还在手撕微服务?快试试 go-zero 的微服务自动生成

万俊峰Kevin

微服务 microservice go-zero Go 语言

SwiftGG 文档翻译笔记1-基础部分函数闭包

Flink SQL CDC 上线!我们总结了 13 条生产实践经验

Apache Flink

flink

RabbitMQ 重要概念介绍

hepingfly【gzh:和平本记】

Java RabbitMQ 消息队列 JMS

直播风口,是什么在支撑教育、电商、泛娱乐等场景?

腾讯云音视频

腾讯云 音视频 云直播 点播

为什么区块链能成为全球贸易的助推器

CECBC

区块链 金融 国际贸易

Spring IoC 到底是什么?

小齐本齐

spring 程序员 ioc Spring Framework Spring Bean

如何搭建第一个 Spring 项目?

小齐本齐

spring Spring Framework Spring Bean

理财专题一

TCA

Http请求中如何保持状态?

架构师修行之路

基于 Flink 的典型 ETL 场景实现方案

Apache Flink

flink

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