/multi-tenancy-spring-boot-starter

multitenancy

Primary LanguageJavaApache License 2.0Apache-2.0

简介

multi-tenancy-datasource-spring-boot-starter 是一个基于springboot的多租户的开发神器. 包含了多租户场景下业务封装和组件抽象。

特性

  • 数据库隔离模型: 基于Postgresqlschemadatabase 级别隔离
  • Redis隔离模型: 为每个key增加租户前缀
  • 租户标识解析: 从Cookie, Header, Domain,URL Path,Env中解析租户标识
  • 租户标识传递: 支持Seata, Feign, RestTemplate
  • 数据源: 多个租户复用数据库Connection减少资源消耗,也可使用独立数据源
  • 动态注册租户: 基于Redis Stream在运行期注册租户
  • postgresql 中表DDL对比和模版Schema,方便新增租户和查看其差异
  • 租户业务执行器: 设置和释放当前线程的租户上下文,执行定制业务功能. 满足定制化业务处理场景
  • 扩展cola组件,使用扩展点的方式扩展租户业务. 满足定制化业务处理场景
  • 抽象租户定制化配置类TenantCustomization,租户动态脚本引擎.TenantDynamicScriptExecutor满足定制化业务逻辑的开发。
  • 动态定义接口组件,满足定制化报表类,简单CRUD类,定制化数据列表类业务

Redis

  • 为每个租户增加不同的key前缀来做数据隔离

DB

architecture.png

使用方式

  • Maven
<dependency>
    <groupId>cc.sofast.infrastructure</groupId>
    <artifactId>multi-tenancy-datasource-spring-boot-starter</artifactId>
    <version>{lastverion}</version>
</dependency>
  • Gradle
implementation 'cc.sofast.infrastructure:multi-tenancy-datasource-spring-boot-starter:{lastverion}'
  • jdk17 启动时需要的参数
--add-opens java.base/java.lang=ALL-UNNAMED --add-opens java.base/java.lang.invoke=ALL-UNNAMED --add-opens java.base/java.util=ALL-UNNAMED --add-opens java.base/java.lang.reflect=ALL-UNNAMED --add-opens java.base/java.text=ALL-UNNAMED --add-opens java.desktop/java.awt.font=ALL-UNNAMED --add-opens java.base/java.nio=ALL-UNNAMED