SpringBlade微服务开发平台
- 采用前后端分离的模式,前端开源两个框架:Sword (基于 React、Ant Design)、Saber (基于 Vue、Element-UI)
- 后端采用SpringCloud全家桶,并同时对其基础组件做了高度的封装,单独开源出一个框架:BladeTool
- BladeTool已推送至Maven中央库,直接引入即可,减少了工程的臃肿,也可更注重于业务开发
- 集成Sentinel从流量控制、熔断降级、系统负载等多个维度保护服务的稳定性。
- 注册中心、配置中心选型Nacos,为工程瘦身的同时加强各模块之间的联动。
- 使用Traefik进行反向代理,监听后台变化自动化应用新的配置文件。
- 极简封装了多租户底层,用更少的代码换来拓展性更强的SaaS多租户系统。
- 借鉴OAuth2,实现了多终端认证系统,可控制子系统的token权限互相隔离。
- 借鉴Security,封装了Secure模块,采用JWT做Token认证,可拓展集成Redis等细颗粒度控制方案。
- 稳定生产了一年,经历了从Camden -> Hoxton的技术架构,也经历了从fat jar -> docker -> k8s + jenkins的部署架构
- 项目分包明确,规范微服务的开发模式,使包与包之间的分工清晰。
架构图
此版本更新内容包括:
- 升级 SpringBoot 至 2.2.11.RELEASE
- 升级 SpringCloud 至 Hoxton.SR8
- 升级 AlibabaCloud 至 2.2.3.RELEASE
- 升级 Knife4j 至 2.0.6
- 升级 Swagger 至 2.10.5
- 升级 SwaggerModel 至 1.6.2
- 升级 SpringPlugin 至 2.2.0.RELEASE
- 升级 JustAuth 至 1.15.8
- 升级 FastJson 至 1.2.74
- 升级 Guava 至 30.0-jre
- 升级 JJWT 至 0.11.2
- 集成UReport2,新增在线报表模块
- 优化Swagger封装以支持Knife4j最新API
- 引入Knife4j增强配置,生产环境将完全隔离文档访问
- 优化架构,适配最新版本API
- 优化部署脚本
注意:本文归作者所有,未经作者允许,不得转载