MyBatis-Plus 多租户架构

1. 多租户概念

  多租户是一种软件架构技术(单实例架构),是实现如何在多用户(面向企业用户)环境下公用相同的系统或程序组件,并且确保各用户间数据的隔离性。核心就是在同一套程序下实现多用户数据的隔离性

2. 数据隔离方案(以Mysql为例)

  A. 独立数据库,相同的表:即一个租户一个数据库,该方案的用户数据隔离级别最高,安全性最好,但成本较高。

   优点:为不同的租户提供独立的数据库,可满足不同租户的独特需求,如果出现故障,恢复数据比较简单;

   缺点:数据库变多了,维护成本也变高了。

  B. 共数据库,共表:这个需要在表中增加租户字段tenantId来区分不同租户的数据。

   优点:维护成本低;

   缺点:隔离级别低,安全性低,数据备份和恢复较困难。

3. 实现方案资料可参考:多租户SQL解析器

    

posted @ 2020-05-06 22:32  如幻行云  阅读(2024)  评论(0编辑  收藏  举报