多租户数据隔离的三种方案

一、多租户在数据存储上存在三种主要的方案,分别是:

1. 独立数据库

这是第一种方案,即一个租户一个数据库,这种方案的用户数据隔离级别最高,安全性最好,但成本较高。
  优点:
    为不同的租户提供独立的数据库,有助于简化数据模型的扩展设计,满足不同租户的独特需求;如果出现故障,恢复数据比较简单。
  缺点:
    增多了数据库的安装数量,随之带来维护成本和购置成本的增加。
  这种方案与传统的一个客户、一套数据、一套部署类似,差别只在于软件统一部署在运营商那里。如果面对的是银行、医院等需要非常高数据隔离级别的租户,可以选择这种模式,提高租用的定价。如果定价较低,产品走低价路线,这种方案一般对运营商来说是无法承受的。

2. 共享数据库,独立 Schema

这是第二种方案,即多个或所有租户共享Database,但是每个租户一个Schema(也可叫做一个user)。底层库比如是:DB2、ORACLE等,一个数据库下可以有多个SCHEMA
  优点:
    为安全性要求较高的租户提供了一定程度的逻辑数据隔离,并不是完全隔离;每个数据库可支持更多的租户数量。
  缺点:
    如果出现故障,数据恢复比较困难,因为恢复数据库将牵涉到其他租户的数据;
  如果需要跨租户统计数据,存在一定困难。

3. 共享数据库,共享 Schema,共享数据表

这是第三种方案,即租户共享同一个Database、同一个Schema,但在表中增加TenantID多租户的数据字段。这是共享程度最高、隔离级别最低的模式。
  即每插入一条数据时都需要有一个客户的标识。这样才能在同一张表中区分出不同客户的数据。
  优点:
    三种方案比较,第三种方案的维护和购置成本最低,允许每个数据库支持的租户数量最多。
  缺点:
    隔离级别最低,安全性最低,需要在设计开发时加大对安全的开发量; 数据备份和恢复最困难,需要逐表逐条备份和还原。

如果希望以最少的服务器为最多的租户提供服务,并且租户接受牺牲隔离级别换取降低成本,这种方案最适合。
    
  在SaaS实施过程中,有一个显著的考量点,就是如何对应用数据进行设计,以支持多租户,而这种设计的思路,是要在数据的共享、安全隔离和性能间取得平衡。

因为我们用的底层库是MySQL,且要保证数据的完全隔离,所以用的方案属于第一种。独立数据库。因为MySQL下SCHEMA就是他的数据库名。所以每多服务一个用户,都需要新建一个数据库。如果是DB2或者是ORACLE的话,一个数据库下,可以采用独立的SCHEMA来进行数据隔离,这样会相对节省成本,且数据隔离的强度高。

二、选择合理的实现模式

衡量三种模式主要考虑的因素是隔离还是共享。

1. 成本角度因素

隔离性越好,设计和实现的难度和成本越高,初始成本越高。共享性越好,同一运营成本下支持的用户越多,运营成本越低。

安全因素

要考虑业务和客户的安全方面的要求。安全性要求越高,越要倾向于隔离。

从租户数量上考虑

主要考虑下面一些因素
    系统要支持多少租户?上百?上千还是上万?可能的租户越多,越倾向于共享。
    平均每个租户要存储数据需要的空间大小。存贮的数据越多,越倾向于隔离。
    每个租户的同时访问系统的最终用户数量。需要支持的越多,越倾向于隔离。
    是否想针对每一租户提供附加的服务,例如数据的备份和恢复等。这方面的需求越多, 越倾向于隔离

技术储备

共享性越高,对技术的要求越高。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论
SaaS多租户系统的数据隔离是指为每个租户提供独立的数据库系统,以保证每个租户的数据和配置信息都是相互隔离的。这种方案的优点是隔离性好,每个租户的数据都是独立的,不会相互干扰,同时也方便数据备份和恢复。但是这种方案的缺点是需要为每个租户提供独立的数据库,会增加系统的维护成本和资源消耗。 下面是一个Python Flask框架的例子,演示如何实现SaaS多租户数据隔离: ```python from flask import Flask, g from flask_sqlalchemy import SQLAlchemy app = Flask(__name__) app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:////tmp/test.db' app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False app.config['SQLALCHEMY_ENGINE_OPTIONS'] = {'pool_size': 100, 'pool_recycle': 280} db = SQLAlchemy(app) class Tenant(db.Model): id = db.Column(db.Integer, primary_key=True) name = db.Column(db.String(50), unique=True, nullable=False) class User(db.Model): id = db.Column(db.Integer, primary_key=True) name = db.Column(db.String(50), unique=True, nullable=False) tenant_id = db.Column(db.Integer, db.ForeignKey('tenant.id'), nullable=False) @app.before_request def before_request(): tenant_name = get_tenant_name_from_request() g.tenant = Tenant.query.filter_by(name=tenant_name).first() @app.teardown_request def teardown_request(exception): db.session.remove() def get_tenant_name_from_request(): # 从请求中获取租户名 pass @app.route('/users') def get_users(): users = User.query.filter_by(tenant_id=g.tenant.id).all() return jsonify([user.name for user in users]) ``` 在这个例子中,我们使用了Flask框架和SQLAlchemy库来实现SaaS多租户数据隔离。我们定义了两个模型类Tenant和User,分别表示租户和用户。在before_request函数中,我们从请求中获取租户名,并通过查询数据库获取租户对象,将其保存在g对象中。在teardown_request函数中,我们关闭数据库连接。在get_users函数中,我们通过过滤租户ID来获取该租户下的所有用户,并返回用户列表。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不对法

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值