基于微服务和DDD的架构模板
常用技术选型
- 反向代理:Nginx
- 开发框架:Spring Boot
- 数据库:MySQL
- 缓存:Redis
- 微服务解决方案:Spring Cloud Alibaba
- 注册中心:Nacos
- 配置中心:Nacos
- MQ:RocketMQ / RabbitMQ
- 监控报警:Prometheus
- OSS文件系统:Minio
- 志系统:Promtail + Loki + Grafana or ELK
- CI/CD:Jenkins
- 任务中心:xxl-job
- 软件交付:Docker镜像
逻辑架构模板
- 分层:UI 、 前台、中台、基础设施
- DDD: 中台采用
DDD
架构设计,按领域进行设计、开发,各领域间通过注册中心
进行服务注册和服务发现,通过FeignClient
进行调用 - 中台网关:中台服务通过
中台网关
发布给前台应用,前台通过HttpClient
调用网关接口,网关通过服务发现和负载均衡
转发前台请求到中台 - 基础设施:所有依赖外部的基础设施抽象
基础设施接口层
,基础设施层做具体的实现,中台应用只依赖基础设置接口层
- Portal: 开放Portal服务(开放平台),用于外部系统调用和系统回调
- 日志收集系统
- 系统监控&告警
- 埋点统计