企业级的 SaaS 多租户微服务平台 SpringBlade 项目,源码分享
需要获取文章中的源码与文档的小伙伴,记得一键三连哦
添加 V?:tulingQY 备注(888)可以免费获取到哦
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 -> Greenwich 的技术架构,也经历了从 fat jar -> docker -> k8s + jenkins 的部署架
构
项目分包明确,规范微服务的开发模式,使包与包之间的分工清晰。
架构图
===
工程结构
====
SpringBlade
├── blade-auth -- 授权服务提供
├── blade-common -- 常用工具封装包
├── blade-gateway -- Spring Cloud 网关
├── blade-ops -- 运维中心
├ ├── blade-admin -- spring-cloud 后台管理
├ ├── blade-develop -- 代码生成
├ ├── blade-resource -- 资源管理
├ ├── blade-seata-order -- seata 分布式事务 demo
├ ├── blade-seata-storage -- seata 分布式事务 demo
├── blade-service -- 业务模块
├ ├── blade-desk -- 工作台模块
├ ├── blade-log -- 日志模块
├ ├── blade-system -- 系统模块
├ └── blade-user -- 用户模块
├── blade-service-api -- 业务模块 api 封装
├ ├── blade-desk-api -- 工作台 api
├ ├── blade-dict-api -- 字典 api
├ ├── blade-system-api -- 系统 api
└── └── blade-user-api -- 用户 api
BladeX 工作流一览
============
评论