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...

核心业务身份识别

类图

注册流程

调用流程

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

相关推荐
涡能增压发动积19 小时前
同样的代码循环 10次正常 循环 100次就抛异常?自定义 Comparator 的 bug 让我丢尽颜面
后端
Wenweno0o19 小时前
0基础Go语言Eino框架智能体实战-chatModel
开发语言·后端·golang
swg32132119 小时前
Spring Boot 3.X Oauth2 认证服务与资源服务
java·spring boot·后端
tyung19 小时前
一个 main.go 搞定协作白板:你画一笔,全世界都看见
后端·go
gelald19 小时前
SpringBoot - 自动配置原理
java·spring boot·后端
殷紫川20 小时前
深入拆解 Java 内存模型:从原子性、可见性到有序性,彻底搞懂 happen-before 规则
java·后端
元宝骑士20 小时前
FIND_IN_SET使用指南:场景、优缺点与MySQL优化策略
后端·mysql
用户319523703477120 小时前
记一次 PostgreSQL WAL 日志撑爆磁盘的排查
后端
nghxni20 小时前
LightESB PlatformHttp v3.0.0:JSONPath 订单转换 HTTP 路由实战
后端
武子康20 小时前
大数据-263 实时数仓-Canal 增量订阅与消费原理:MySQL Binlog 数据同步实践
大数据·hadoop·后端