专栏简介
使用Axon框架基于DDD领域驱动设计、CQRS读写分离和事件溯源(Event Sourcing)来实现货物运输系统(Cargo Tracker Application)
专栏介绍
Axon Framework 通过支持开发者应用命令查询职责分离(CQRS)架构模式,来帮助构建可伸缩、可扩展和可维护的应用程序。它通过提供最重要的构建块来实现,如聚合、仓储以及事件总线(事件的调度机制)等等。此外,Axon提供了对注解的支持,它允许你构建聚合和事件监听器而不用将你的代码捆绑到Axon特有的逻辑。
DDD的思想提出了一些概念,一些模式,让你的代码看起来更贴合自然语义,更贴近业务人员的思维,极力去消除开发人员和业务人员之间的代沟,另外非常重要的就是它界定了业务领域中的各种操作边界如何划分的原则,划定上下文范围,防止出现盘根错节的复杂调用关系。
Axon框架实现了这些思想,建立了一整套让你可以在专注于业务实现的同时,又能很简单地利用高级技术进行灵活处理的框架体系。
专栏大纲
本技术专栏以货物运输系统(Cargo Tracker Application )为示例,我们将使用Axon框架基于DDD领域驱动设计、CQRS命令查询职责分离架构、事件溯源(Event Sourcing)来实现。
Axon忠实地贯彻了DDD的思想,虽然第一次开发复杂度有所提升,但它所增加的工作量都是为了避免我们走弯路。一旦做成,项目长远的可维护性可扩展性以及性能的优化点,都能极大地提升。
DDD领域驱动、CQRS读写分离、ES事件溯源(Event Sourcing)-这些前沿的时髦的技术理念汇聚在一次,落地到一套完整实现方案,这就是Axon框架。
主要内容如下:
-
DDD领域驱动设计和Axon框架快速入门
-
CQRS命令查询职责分离和Event Soucing事件溯源组合设计
-
Axon框架详细介绍:领域模型、调度模型和基础设施
-
Axon框架详细介绍:Axon基础设施组件Axon Server和控制台演示
-
基于Axon框架实现货物运输系统
适合人群
本专栏主要面向有一定Java项目开发实践经验的软件开发人员、架构师、软件专家等等。或者希望学习DDD领域驱动设计、CQRS命令查询职责分离架构、ES事件溯源等等技术人员。
学习收获
通过Axon框架快速入门,学习并实践DDD领域驱动设计思想、CQRS命令查询职责分离架构、ES事件溯源等技术,并结合实际的货物运输系统(Cargo Tracker Application)应用项目和源代码,对Axon框架、DDD建模过程以及代码落地获得更加深入的理解。