阿里开源COLA4。0Part3
COLA分层架构
COLA4。0架构分成COLA架构和COLA组件两个部分:COLA架构:关注应用架构的定义和构建,提升应用质量。COLA组件:提供应用开发所需要的可复用组件,提升研发效率。
COLA4。0框架
COLA架构:关注应用架构的定义和构建,提升应用质量。领域模型对设计能力要求很高,没把握用好,一个错误的抽象还不如不抽象,宁可不要用,也不要滥用,不要为了DDD而DDD。
COLA架构各个包结构的简要功能描述,如下表所示:
层次
包名
功能
必选
Adapter层
web
处理页面请求的Controller
否
Adapter层
wireless
处理无线端的适配
否
Adapter层
wap
处理wap端的适配
否
App层
executor
处理request,包括command和query
是
App层
consumer
处理外部message
否
App层
scheduler
处理定时任务
否
Domain层
model
领域模型
否
Domain层
ability
领域能力,包括DomainService
否
Domain层
gateway
领域网关,解耦利器
是
Infra层
gatewayimpl
网关实现
是
Infra层
mapper
ibatis数据库映射
否
Infra层
config
配置信息
否
ClientSDK
api
服务对外透出的API
是
ClientSDK
dto
服务对外的DTO
是
COLA组件:提供了一些框架级别的功能,提供应用开发所需要的可复用组件,提升研发效率。
组件名称
功能
版本
依赖
colacomponentdto
定义了DTO格式,包括分页
1。0。0
无
colacomponentexception
定义了异常格式,主要有BizException和SysException
1。0。0
无
colacomponentstatemachine
状态机组件
1。0。0
无
colacomponentdomainstarter
Spring托管的领域实体组件
1。0。0
无
colacomponentcatchlogstarter
异常处理和日志组件
1。0。0
exception,dto组件
colacomponentextensionstarter
扩展点组件
1。0。0
无
colacomponenttestcontainer
测试容器组件
1。0。0
无
参考:《COLA4。0:应用架构的最佳实践》COLA框架职责划分
COLA框架主要分为适配层、应用层、Client模块、领域层、基础设施层
分层架构如下:
COLA4。0分层架构
分包结构如下:
COLA4。0包结构模型
1)适配层(AdapterLayer):负责对前端展示(web,wireless,wap)的路由和适配,对于传统BS系统而言,adapter就相当于MVC中的controller;
适配层代码结构
2)应用层(ApplicationLayer):主要负责获取输入,组装上下文,参数校验,调用领域层做业务处理,如果需要的话,发送消息通知等。层次是开放的,应用层也可以绕过领域层,直接访问基础实施层;
应用层代码结构
3)Client模块(ClientModule):包含的代码应该是常见的服务接口Facade和DTO数据传输对象,如API、DTO、领域事件、Command和Query对象等等。
Client模块
4)领域层(DomainLayer):主要是封装了核心业务逻辑,并通过领域服务(DomainService)和领域对象(DomainEntity)的方法对App层提供业务实体和业务逻辑计算。领域是应用的核心,不依赖任何其他层次;
领域层包结构
5)基础实施层(InfrastructureLayer):主要负责技术细节问题的处理,比如数据库的CRUD、搜索引擎、文件系统、分布式服务的RPC等。此外,领域防腐的重任也落在这里,外部依赖需要通过gateway的转义处理,才能被上面的App层和Domain层使用。
基础实施层
6)启动模块(StartModule):SpringBoot的启动类,应用入口。没有任何逻辑,只需要配置application。properties配置文件。
启动模块CQRS架构模式
CQRS架构模式,在DDD中是一种很常见的模式,它的用途在于将Command与Query功能进行分离,让一些复杂的查询摆脱领域模型的限制,以更为简单的DTO形式展现查询结果。服务可以独立部署,也可以拆分部署。数据库可以使用一个,也可以读写分离。
CQRS架构
在COLA4。0中,已经移除了CommandBus和QueryBus的处理,进一步简化了COLA架构。业务调用时序图
我们通过分三个场景的UML时序图描述一下各模块之间的调用关系。主要差异在于应用层中的Command或Query执行器的处理过程。
场景一:Command或Query执行器直接调用Gateway接口,处理业务请求。
UML时序图:场景一
场景二:Command或Query执行器,调用领域服务(DomainService),然后领域服务调用Gateway完成业务请求。
UML时序图:场景二
场景三:Command或Query执行器直接调用infrastructure层中定义的Mapper,完成业务逻辑处理。
UML时序图:场景三
下面说明整体调用过程和注意事项。Adapter接收CmdQry对象或者参数列表(RequestParam)。如果请求参数是参数列表,则构造CmdQry对象,然后调用AppService接口。App服务接收CmdQry对象,然后调用CmdQryExecutor(执行器),如上图所示,分为以下三种场景:
2。1。CommandExecutor可以通过领域实体方法,以及Gateway接口,实现简单业务编排,完成业务请求。
2。2。或者通过调用领域服务(DomainService)实现复杂业务逻辑处理,然后在领域服务通过Gateway访问数据的持久化。
2。3。或者直接跳过Domain层,在QryExecutor中调用infrastructure中的Mapper接口,访问数据库持久化操作。App服务、CommandExecutor(命令执行器)以及DomainSerivce都是无状态服务,本身不存储任务信息。App服务负责实现对外暴露的API服务,然后调用CommandExecutor。DomainService负责封装一个领域中跨实体操作的业务逻辑。AppService负责封装跨领域实体操作的业务逻辑。Gateway接口用来隔离技术实现细节,GatewayImpl实现领域层定义的Gate接口,负责数据的CRUD操作,数据库测可以是MySQL、NoSql、Elasticsearch、Redis、甚至HadoopHBase等分层架构、包结构、业务调用关系
下图将COLA分层架构、包结构、业务调用关系,整合在一张图中。
COLA分层架构、包结构、以及业务调用关系图
代码参考:《COLA4。x架构入门和项目实践》
二十大特刊欠发达省份的脱贫故事中国经济周刊记者贾璇北京报道过去是树木被砍光水土流失光姑娘也跑光的三光村,现在是光荣脱贫光彩夺目光明前景的新三光村。这是党的二十大代表来自云南省西畴县蚌谷乡海子坝村村民谢成芬,讲述
散文丨王亮古城的秋古城的秋文王亮零陵,是一座有着两千多年悠久历史的古城,也是国家级历史文化名城,岁月为它增添了许多神秘又赋予了独特的魅力。生于斯长于斯,自然对它有着一种如艾青所写因为我对这土地爱得深
美景山东无棣古城融合齐燕河海等多种文化的千年古城美景山东,精彩无限。无棣古城位于山东省滨州市无棣县,规划总面积为3。1平方公里,现为国家AAAA级旅游景区。无棣是山东的千年古县之一。无棣一词最早见于左传僖公四年传。公元前656年
荆州古城外一条道路将打通,老南门要大变样提到荆州老南门,你第一印象是什么?是觉得这里非常热闹很有烟火气呢?还是觉得这里有点脏乱差,跟古城风貌不协调。可能从不同的角度,你会得出不一样的结论。老南门,大名叫南纪门,城门上原本
神秘银杏即将蜕变,哪张才是你的菜在曲江楼观生态文化旅游度假区宗圣宫内有一棵老子手植的银杏树据传,这棵银杏有2500多年树龄,且银杏树曾经遭遇火灾,树干中心部分烧毁中空。然而,即便如此,他依旧屹立不倒,年年叶落长安
肇庆有座神秘岛屿800年来,不与外通,保留了古朴文化国庆小长假错峰出游,避开人流量大的景点和高速,从佛山出发,这次走到肇庆砚洲岛,自驾只需一小时,一路畅通无阻,骑车到农田边一片成熟的稀谷等着农民收成明清时期,百姓为纪念包公,在岛上修
神秘的第六感头条创作挑战赛众所周知,人有五感,即视觉听觉嗅觉味觉触觉,但有人认为人类其实还具有第六种感觉,利用这种感觉,可以观察到一些平时看不见的事物,例如灵异事件,然而这种说法着实天马行空,
嚣张将军当丞相后,要求娶皇后为妻,皇后我老了,把女儿嫁给你元朝是中国历史上最强大而又最缺乏存在感的朝代,这个威震世界的庞大王朝仅仅存在了98年的时间。紊乱的皇位继承,频繁的政治斗争,残酷的等级制度是这个王朝留给世人的最深印象。这个王朝发生
10。27早盘预案一股神秘的东方力量收复大盘3000点?今天市场普涨行情,涨停家数也突破近期新高,达到80家市场一片欣欣向荣,我大宵哥更是在早盘就喊出一股刚强的力量收复3000点但是我们应该坚决不做市场追涨喊跌的弱者盲目跟从只会让我们的
不知火舞新皮肤绯月行上线,神秘商店上新,史诗皮肤宝箱名单出炉你好,我是小酒。王者荣耀七周年前的最后一次更新,放出了很多的东西,包括了七周年的奖励,以及刚曝光的新皮肤上线。不知火舞的新皮肤绯月行,终于正式爆料。海报中,一轮红月,还有很多小妖都
赵丽颖一袭吊带小黑裙,大秀完美身材,神秘优雅,美呆了10月26日赵丽颖现身CL彩妆直播,一袭镶钻黑色吊带小黑裙,满满的性感诱惑!直播现场,赵丽颖虽然一身黑色性感装扮,可时不时低头抿嘴浅笑,又透露着点儿娇羞可爱!直播结束后,赵丽颖工作