今天给大家推荐一个牛逼的接私活项目,SpringCloud微服务架构项目!
一个由商业级项目升级优化而来的微服务架构,采用SpringBoot 2.6 、SpringCloud 等核心技术构建,提供基于React和Vue的两个前端框架用于快速搭建企业级的SaaS多租户微服务平台。
架构图
项目介绍
1、采用前后端分离的模式,前端开源两个框架:Sword (基于 React、Ant Design)、Saber (基于 Vue、Element-UI)
2、后端采用SpringCloud全家桶,并同时对其基础组件做了高度的封装,单独开源出一个框架:BladeTool
3、BladeTool已推送至Maven中央库,直接引入即可,减少了工程的臃肿,也可更注重于业务开发
4、集成Sentinel从流量控制、熔断降级、系统负载等多个维度保护服务的稳定性。
5、注册中心、配置中心选型Nacos,为工程瘦身的同时加强各模块之间的联动。
6、使用Traefik进行反向代理,监听后台变化自动化应用新的配置文件。
7、极简封装了多租户底层,用更少的代码换来拓展性更强的SaaS多租户系统。
8、借鉴OAuth2,实现了多终端认证系统,可控制子系统的token权限互相隔离。
9、借鉴Security,封装了Secure模块,采用JWT做Token认证,可拓展集成Redis等细颗粒度控制方案。
10、稳定生产了三年,经历了从 Camden -> Hoxton -> 的技术架构,也经历了从fat jar -> docker -> k8s + jenkins的部署架构。
11、项目分包明确,规范微服务的开发模式,使包与包之间的分工清晰。
工程结构
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
用户权益
仅允许免费用于学习、毕设、公司项目、私活等。
界面