写点什么

面向 XML 的领域建模设计

  • 2007-10-30
  • 本文字数:2171 字

    阅读完需:约 7 分钟

在领域驱动设计(DDD:Domain Driven Design)中,实现业务逻辑层主要有三种模式 [1]:Transaction Script、Domain Module 和 Table Module。随着业务逻辑复杂程度的增加,采用各模式实现的工作量变化趋势有所不同;根据应用特点,三种模式也各有优势:

  1. Transaction Script:业务逻辑直接用 SQL 脚本与数据库交互,实现简单,但是限于 SQL 面向过程化的特点,完成复杂业务逻辑时工作量较大。
  2. Domain Module:将业务数据封装为业务对象,适于业务逻辑复杂的应用,但需要 O/R 映射的支持。
  3. Table Module:将业务数据组织成数据表方式,虽然对象化特征不如 Domain Module 明显,但适于展现层使用。

图 1:实现所需工作量与业务逻辑复杂度的关系

应用建设初期选择的实现模式随着业务需求和历史数据量的变化可能需要进行调整,此时要增加一个适应性机制,保证在尽量不影响客户程序的前提下,选择合适的实现模式。随着 XML 数据使用日趋广泛,须借助 XPath、XQuery 和 XSL 为层次型数据增加专门的扩展机制,使得基于 XML 数据源的业务逻辑也可以采用上述三种模式实现。

概要设计

整体逻辑结构

总体适配机制如下:

图 2:总体实现结构

为业务服务增加抽象接口 IDomainService,客户程序通过 DomainServiceFactory 获得该抽象接口,这样客户程序不依赖于具体的业务服务实体类,仅依赖于抽象的服务接口,当下层实现模式调整时,不影响客户程序;为了让框架可以同时适应关系数据库和 XML 数据,增加了抽象接口 IDataSource,代表不同的数据源对象;IDataMapper 负责根据不同的数据源,完成关系数据或 XML 数据与业务对象的映射;为了减少 DomainServiceFactory 与具体业务服务对象产生依赖,增加配置管理对象 ConfigManager,由它获取指定的业务服务的实体类名称,并通过反射机制动态生成目标实例。

性能改进

由于业务实体经常会对应到具有 Master-Detail 关系的多个表,而且有些复杂业务实体本身会包含一组或几组其它业务实体,出于性能考虑,为了避免 IDataMapper 在映射过程中频繁调用数据源逐个生成子业务实体,需要在 IDataMapper 与数据源之间增加一个 DTO(Data Transfer Object) 对象 IDataTransferObject,通过将调用打包的办法,减少频繁的远程调用。

图 3:借助 DTO,Domain Module 对象间接访问数据源

详细设计

面向关系数据库的业务服务设计

为了将业务实体纳入适配机制的管理,依据依赖倒置原则,先对各模式实现的业务实体进行抽象。

图 4: 关系数据库方式下的适配机制

为每种模式实现的业务对象抽象独立接口,并编写对应的关系数据库实现类;Domain Module 需要调度数据映射和 DTO 进行关系数据与业务实体的映射;增加抽象基类 DomainModuleBase,通过调用 IDataMapper 和 IDataTransferObject 完成数据提取和映射工作。

表 1:关系数据库下三种模式的执行特征

面向 XML 数据的扩展设计

由于 XML 的层次特征,3 个模式的实现技术与关系数据库不同:

表 2:XML 数据下三种模式的执行特征

图 5: XML 数据方式下的适配机制

配置机制设计

通过增加服务接口工厂类的方式隔离客户程序与具体业务服务实体类间的依赖,工厂类通过配置管理 ConfigManager 获得每个目标服务接口对应的实体类名称,借助反射动态包装目标服务接口。静态结构和执行过程如下:

图 6:配置管理机制

图 7:客户程序获得业务服务接口的时序关系

实验环境准备及实验结果分析

测试业务对象

为了比较三种模式实现特点的不同,测试中设计了 2 个具有 Master-Detail 特征的业务实体:Customer 和 Order,两者之间也存在 1:N 的关系,对应的关系数据库和 XML 数据实现如下:

图 8:业务实体

图 9:关系数据库方式下业务实体实现

图 10:XML 数据方式下业务实体的实现

目标服务是一个根据客户名称,返回其所有订单明细项小计之和的接口。

测试内容准备

针对关系数据库和 XML 数据方式的不同,业务逻辑如表 3。其中,XML 数据的 Transaction Script 模式为了计算简单,增加一个采用 XSTL 生成 “客户名称—订单项明细小计”的中间过程:

图 11:XML

Transaction Script 方式下生成中间结果的 XSLT

表 3:两种数据模型下三个实现模式的计算方法

测试数据

表 4:测试数据

测试结果及分析

通过修改 ConfigManager 中实现业务服务的实体类名称,结合数据库调用监控获得如下数据:

表 5:测试结果

测试结果分析如下:

1)借助适配机制,在目标实现模式甚至数据模型修改时,客户程序保持稳定,修改内容控制在配置文件部分,不影响客户程序的业务逻辑;

2)使用不同模式设计完成的业务对象,借助适配机制和 XML 数据扩展机制,在关系数据库和 XML 数据方式下,可完成同样的服务功能;

3)通过 DTO 组件的调用打包作用,可以将包括 2 份订单、4 项订单明细的信息一次性提取,将多次调用打包为 1 次调用,减少了网络往复。

总结

依据依赖导致原理设计的适配机制可以从一定程度上减少客户程序与业务逻辑的耦合程度,在部署、运行环境变化时,可通过调整配置选择合适的业务逻辑实现模式,并且不需要客户程序联动修改;DTO 对象的加入可以减少分布式调用中的往复次数,对应用性能的提升有利。实际工程中,由于业务逻辑实体往往需要被多个客户程序调用,需要有效的并发机制配合,后续研究中将着重对并发能力进行调整。

参考文献:

[1] Fowler, Martin 著,Patterns of Enterprise Application Architecture

[2] Biping Joshi 著,Pro .Net 2.0 XML

源代码下载: DomainMechanism

2007-10-30 22:561663
用户头像

发布了 61 篇内容, 共 11.7 次阅读, 收获喜欢 0 次。

关注

评论

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

TypeScript | 第六章:理解声明合并,以及编写声明文件

梁龙先森

typescript 大前端 七日更

瞬间起飞!腾讯大神纯手撸“架构师成手册”网友看完直呼NB!

比伯

Java 编程 架构 面试 计算机

华为大佬亲自手码Dubbo服务暴露源码解析!这次够清楚了吧

比伯

Java 编程 架构 程序人生 计算机

亚马逊 CTO 预测 2021 将改变世界的八大技术趋势:云加速向边缘推进

亚马逊云科技 (Amazon Web Services)

云计算 AWS

第十周学习总结

晴空万里

极客大学架构师训练营

浅谈优秀工程师的成长因素

数据社

程序员 七日更

架构师训练营 第十周作业

文江

Presto入门

Albert

presto 七日更

北漂七年Java开发的一路辛酸史:面试腾讯、阿里、美团、字节后的一点心得

Java架构之路

Java 程序员 架构 面试 编程语言

微服务网关的技术架构

积极&丧

第五周命题作业

cc

科技抗疫,少年可期,为这群有AI的天使开发者疯狂打call

华为云开发者联盟

人工智能 华为云 modelarts 医疗AI 对象存储服务OBS

注册中心Eureka源码解析

洛神灬殇

星环科技作为信通院隐私计算联盟成员亮相2020数据资产管理大会

星环科技

大数据

史上最全1000道Java高频面试题:集合、IO流、多线程、网络、算法、Git、设计模式、springboot

Java架构之路

Java 程序员 架构 面试 编程语言

大厂offer直通车:并发编程28题+JVM21题+Redis 16题+Java集合22题

Java架构之路

Java 程序员 架构 面试 编程语言

2021年阿里、腾讯、百度、华为、京东、美团和滴滴最新Java面试题汇集!

Java架构之路

Java 程序员 架构 面试 编程语言

bit位操作及其算法应用

Skysper

算法 位运算

久等了,Rancher 2.5中文文档新鲜出炉

Rancher

容器 k8s

【mybatis-plus】什么是乐观锁?如何实现“乐观锁”

Java架构师迁哥

第十周课后练习

晴空万里

极客大学架构师训练营

金融知识图谱的构建与应用

DataFunTalk

AI 知识图谱

面试被问:JDBC底层是如何连接数据库的?

田维常

JDBC

Spring源码高级笔记之——Spring AOP应用

Java架构师迁哥

第五周学习心得

cc

分布式缓存架构设计和一致性HASH

我们新四军不拿群众一针一线

一个月吃透这份阿里高级专家的《Java500道面试手册》成功拿下了腾讯offer!

Java架构之路

Java 程序员 架构 面试 编程语言

职责链模式

soolaugust

设计模式 七日更 职责链模式

京东技术解密

田维常

京东

如何使用数据仓库?

数据社

数据仓库 七日更

写技术文章给我带来什么好处?

小林coding

程序人生

面向XML的领域建模设计_.NET_王翔_InfoQ精选文章