COLA

整体架构

github.com/alibaba/COL...

对于各个分层的定义和区分

  • client层,面向应用层对外的服务表达,灵活为主,薄,可随业务、渠道定义独立的api,但是分包结构不能不变化
  • app层,或者是业务逻辑层,面向业务场景的逻辑表达。负责业务编排,一个业务场景的主流流程可以在这一层直观可视,灵活为主,薄。
  • domain层,做领域服务,围绕这一簇模型进行逻辑表达。核心能里的所在地,规范灵活,以沉淀复用为主,使用spi兼顾业务的个性化
  • infra层,基础设施层,基础的配置,内部存储或远程rpc调用,灵活为主,可随db,性能差异独立dao方法

实践中的细节

  • 能够跨层调用dao,可以
  • 厚domain而薄biz,app面向实际的业务场景,而domain面向实际的模型簇
  • 能否跨域调用dao,可以
  • 实物放在同一层,或者是app,或者是domain
  • 域之间不能相互调用
  • 定制点最好在domain层开
  • 依赖倒置,图中是站在domain层进行的依赖倒置,但是如果站在整个应用的角度,那么domain是依赖于Dao的实现的
  • 配置态和运行态需要解耦

系统调用大图

重要组件和功能

日志Aop

核心知识 aop切面 代理模式

  • @CatchAndLog 切面注解
  • CatchLogAspect 日志切面
  • CatchLogAutoConfiguration 切面注册
  • ResponseHandlerI 异常结果处理接口,可以自定义实现

工厂的能力可以根据业务复杂度再进行扩展,不同类型的异常,不同类型的response,CatchAndLog可以再加一些内容

事件

核心是重试,重试监听,执行,执行前处理,执行后处理,异常监听

类图

调用流程

扩展点

blog.csdn.net/significant...

核心业务身份识别

类图

注册流程

调用流程

系统应用开放性的几种形态

相关推荐
重生之我在二本学院拿offer当牌打27 分钟前
秒杀场景下的MySQL优化:从崩溃到抗住100万QPS
后端
重生之我在二本学院拿offer当牌打28 分钟前
IoC容器深度解析(三):Bean生命周期11步骤深度剖析,彻底搞懂Spring核心机制!
后端
重生之我在二本学院拿offer当牌打35 分钟前
手写SpringBoot Starter(三):实现可插拔Starter,像Zuul一样优雅!
后端
初见0011 小时前
🌱 SpringBoot自动配置:别装了,我知道你的秘密!🤫
spring boot·后端
用户785127814701 小时前
Python代码获取京东商品详情原数据 API 接口(item_get_app)
后端
JAVA数据结构1 小时前
BPMN-Activiti-简单流程委托
后端
sivdead1 小时前
智能体记忆机制详解
人工智能·后端·agent
拉不动的猪2 小时前
图文引用打包时的常见情景解析
前端·javascript·后端
该用户已不存在2 小时前
程序员的噩梦,祖传代码该怎么下手?
前端·后端
间彧2 小时前
Redis缓存穿透、缓存雪崩、缓存击穿详解与代码实现
后端