写点什么

论领域驱动设计在微服务开发中的作用

  • 2016-02-17
  • 本文字数:1536 字

    阅读完需:约 5 分钟

在近期于德国柏林举办的 microXchg 大会上,来自 innoQ 的 Michael Plöd 在一场演讲中谈到了如何在开发微服务的过程中使用领域驱动设计(DDD)的话题。在他看来,微服务与DDD 之间的联系不仅仅只限于界限上下文(Bounded Context)的概念而已,虽然界限上下文确实是一种可用于定义微服务粒度的基础工具,但其他一些概念也同样重要。相应地,DDD 也并非只单纯地代表实体、值对象与repository 等概念而已。

Plöd 是 innoQ 的首席顾问。他相信,在创建微服务的过程中,DDD 可以在以下 4 个主要领域发挥作用:

  • 战略设计 —— 这一阶段的主要工作就是界限上下文的设计,但上下文图(Context Map)与其他模式也同样十分重要。
  • 内部构建块 —— 在设计一个界限上下文的内部结构时将用到 DDD 中的多种战术模式,例如实体、聚合以及 repository。
  • 大比例结构(Large-scale Structure),通过有序演化与职责层模式创建结构。
  • 精炼 —— 通过精炼方法,从一个已经成熟的系统中提炼出一个核心领域

任何一个具有高复杂度的业务领域都由一个或多个界限上下文组成,每个上下文负责领域中的一部分内容。每个界限上下文都包含用于描述领域的模型,同时也定义了这些模型所代表的意义的边界。以一个客户对象为例,每个界限上下文都是按照独有的模型与视角来定义这个客户对象的。在 Plöd 看来,这一特性对于开发独立的微服务能够起到重要的促进作用。

上下文图描述了系统中的所有界限上下文,以及他们之间的相互关联及上下文之间的契约。Plöd 相信,对于已有打算进行微服务转型的组织来说,上下文图将带来极大的便利。不仅如此,上下文图还能够作为今后的转型过程中的一个良好的起点。以下是界限上下文之间常见的关系模式:

  • 共享内核模式(Shared Kernel) —— 它表示两个上下文或模型之间共享某个领域的一个子集,包括代码在内。Plöd 提示,这种模式将增加系统的依赖。
  • 客户 / 供应商模式(Customer / Supplier) —— 某个上下文将扮演客户的角色,它将从另一个扮演供应商角色的上下文中请求特性。
  • 防崩溃层(Anticorruption layer, ACL )—— 某个客户端将利用转换器(translator),将其自身的模型与其他模型进行隔离。在将系统转型为微服务或自包含系统(Self-Contained,SCS)架构时,这是一种非常有趣的选择,ACL 将表现为一个系统的护罩,以抵御来自外部的侵扰。

在 DDD 的各种内部构建块中,Plöd 特别提到了聚合的重要性。聚合是由多个领域对象构成的一个逻辑组,其中的对象将作为一个整体进行处理。聚合中的某个实体将成为聚合根,它负责接收所有外部请求,并负责整个聚合的生命周期。

对于僵硬的架构或是过于复杂的系统来说,可以选择创建一个跨界限上下文的大比例结构,让这个结构随着对于高层次概念的理解不断加深而逐渐进化。Plöd 表示,这一点也是微服务架构的核心思想之一,微服务的设计应当是可以不断进化的。职责层模式是另一种在界限上下文之内创建一个内部结构的结构模式,其思想是按照职责进行结构的创建,而微服务的结构也可以应用相同的概念进行设计。

在将某个遗留系统转型至微服务或是自包含系统架构时,精炼方法能够帮助开发者从一个现有的一体性系统中提炼出微服务。首先要辨别并提炼出核心领域,然后再通过迭代方法找出子领域,将其从核心领域中提取出来,最后再进行一些内部的清理与重构工作。Pödl 特别强调了为核心领域的业务功能与细节实现文档化的重要性。如果对于业务功能没有一个清晰的愿景及深刻的理解,就会增加无法发现最佳的界限上下文的风险。

Pödl 在演讲的最后回顾了以上概念,并在总结陈述中表示微服务与 DDD 能够很好地结合在一起。但他同时也提示,开发者应当具有大局观,而不是将注意力仅仅放在界限上下文中。

查看英文原文: Using Domain-Driven Design When Creating Microservices

2016-02-17 18:003746
用户头像

发布了 428 篇内容, 共 199.2 次阅读, 收获喜欢 39 次。

关注

评论

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

Meta force2.0佛萨奇矩阵公排系统开发合约部署搭建

开发微hkkf5566

智能时代如何打通商业市场?华为的内外兼修

这不科技

企业需要进行信息化改革,有哪些好用的信息化管理系统推荐?

优秀

低代码 信息化 信息化管理

5 分钟带你在本地搭建一套云原生实验环境

谢烟客

Kubernetes 云原生 Service Mesh istio kind

3000人群被字节内部技术图谱炸翻了,惊艳级实用

小二,上酒上酒

Java 架构 技术栈 字节

白活了!谷歌架构师10年心血汇成的《24种设计模式》,这才是正解

小二,上酒上酒

Java 设计模式

2023上海国际智慧灯杆及智慧路灯展览会

AIOTE智博会

上海智博会 智慧灯杆展会 智慧路灯展会

共36万字!为上岸Alibaba,我把Github上Java面试题都整理了一遍

小二,上酒上酒

Java 面经 大厂面试 Alibaba Java面经

ZETA精彩亮相2022 IOTE展 以全栈式物联生态赋能产业数智化转型

ZETA开发者

物联网 ZETA 物联网技术 LPWAN 技术融合

面试了个985毕业的大佬,回答“性能调优”题时表情令我毕生难忘

小二,上酒上酒

Java 面试 性能调优

HTAP 的下一步?SoTP 初探(上):从 “大” 数据到 “小” 而 “宽” 数据 —— 第七届中国开源年会(COSCon'22)

StoneDB

MySQL 数据库 开源 HTAP StoneDB

和鲸科技入选2022年度数字化创新服务商丨Digital 36 调研发布

ModelWhale

云计算 大数据 数字化转型 数据智能 企业服务

眼见为实:ForkJoin的“分而治之”,竟然有隐藏的坑?

KINDLING

Java Linux 多线程 forkjoin ebpf

数据报告 | 新冠疫情对美国民众消费行为的影响

前嗅大数据

疫情 数据分析 爬虫 数据采集 消费

大咖说·先临三维|技术入云塑造3D视觉行业新模式

科技pai

阿里云 科技 3D视觉

阿里架构师耗时1年,把P8所需要的整个Java体系,都整理到了一起

小二,上酒上酒

Java 架构 面试

教育行业数据可视化应用方案与实践

葡萄城技术团队

前端 数据可视化 智慧医疗 智慧工程

大数据的5V特征分别是什么?

好程序员IT教育

大数据 V5

数字先锋| 随时随地云端阅片,“云胶片”时代来啦!

天翼云开发者社区

eBPF程序摄像头——力争解决可观测性领域未来最有价值且最有挑战的难题

KINDLING

Java Linux 监控 可观测 #ebpf

栈简介、手撸顺序栈、手撸链栈和栈的应用

C++后台开发

数据结构 后端开发 linux开发 C++开发

物流通知:您的快递即刻送达!

天翼云开发者社区

“元宇宙家园”国脉大厦展馆上线 天翼云实时云渲染筑基未来数字世界

天翼云开发者社区

就这样,进字节了?华为的Java面试题和八股文,真牛批

小二,上酒上酒

Java 面试题 八股文 Java面试题

面试了个阿里P7大佬,他让我见识到什么才是“精通高并发与调优”

小二,上酒上酒

Java 流量 亿级并发设计

眼见为实:关于微服务熔断这几个知识点,你可能理解错了

KINDLING

Java 微服务 熔断 SpringCloud ebpf

还不会正则表达式? 放心 我会出手(万字教学)

坚毅的小解同志

正则表达式 11月月更

【PCB干货】是开窗还是盖油?想搞懂过孔工艺,看这篇就够了!

华秋PCB

PCB PCB设计 过孔 PCB工艺

一文解决 Go 安装和常用环境变量的配置

陈明勇

Go 11月月更

Apache HBase 数据上云实践

移动云大数据

HBase

眼见为实:被误导的Tomcat的工作原理

KINDLING

Java tomcat 多线程 ebpf

论领域驱动设计在微服务开发中的作用_语言 & 开发_Jan Stenberg_InfoQ精选文章