数据库多租户实现三种方式

1960年,许多公司需要使用更多的运算资源,向持有Mainframe的供应商租用运算资源。与此同时,Mainframe的供应商会根据用户登录系统时输入的数据匹配ID,利用ID来计算运算的资源使用量,包含CPU,存储器,软盘或磁带等,此种做法也被SAP公司用在其部分产品线中。

1990年,应用程序服务提供者(application service provider)服务的作法、运作模式与租用大型主机相同,但前者租用的是服务器资源,而后者租用的是软件上的操作系统和应用程序资源,比如:ERP、CRM等应用,系统可能会运行在多台不同的机器上,或是在相同的主机但共享不同的数据库,以区分并计算客户的资源使用量,以此作为计费的标准,而此技术也有效地缩减供应商的实体机器成本。

现在,Web应用程序也是以单一应用程序平台来支持所有用户的,这已经是多租户技术的自然演化的结果,多租户技术也可以让客户中的一部分用户得以进一步定制化他们的应用程序。

在虚拟化(virtualization)技术的成熟与应用性的扩张之下,多租户技术在虚拟化的平台更强化在用户应用程序和数据之间的隔离,让多租户技术能更加发挥它的特色。

定义

多租户技术是指实现了多个企业租户共享同一个应用实例的技术。

实现方式

多租户技术的实现难点是不同租户间的应用程序环境的隔离(application context isolation)以及数据的隔离(data isolation)。

应用程序部分:实现为不同租户提供不同应用程序使用权限,通过进程或是支持多应用程序同时运行的装载环境来做进程间的隔离,或是在同一个伺服程序进程内以运行绪的方式隔离。

数据部分:实现通过不同的机制对不同租户的数据进行隔离,Force是采用中介数据(metadata)的技术来切割,微软MSDN的技术文件则是展示了使用结构描述的方式隔离。

SaaS是多租户技术的应用之一。从架构层面分析,SaaS区别于传统技术的重要差别就是多租户(Muti-Tenant)模式。SaaS多租户在数据存储上存在三种主要的方案,分别是:

1、独立数据库:一个租户一个数据库。这种方案与传统的软件方案相比,优势只是在于软件统一部署在运营商那里,但数据的成本依然没有减少。适用于对数据隔离级别要求非常高的租户,比如:银行、医院等。

优点:数据隔离安全性高,且有助于简化数据模型的拓展设计,满足租户的个性化需求;如果出现故障,恢复数据比较简单。

缺点:维护和购置数据库成本大。

2、共享数据库,隔离数据架构:多个或所有租户共享database,但不同的tenant和schema。

优点:

数据隔离安全性较高,但不是完全隔离;每个数据库可以支持更多的租户数量,降低了数据库成本。

缺点:

如果出现故障,恢复比较困难,因为恢复数据会涉及其他租户的数据;

如果需要跨租户统计数据,存在一定困难。

3、共享数据库,共享数据架构:租户共享一个database、一个schema,在表中通过tenantID区分租户的数据。

优点:

是三种方案中成本最低的方案,允许每个数据库支持的租户数量最多。

缺点:

隔离级别最低,安全性最低,需要在设计开发时加大对安全的开发量;---改动量太大

数据备份和恢复最困难,需要逐表逐条备份和还原。

1、每次开租要在所有schema/database里建同一套表

2、每次版本升级,要刷所有schema/database里的表

否则界面升版,db不升出问题

架构没有绝对的好和坏,只有权衡

PG 解决办法

模式可以用多种方式组织数据。下面是一些建议使用的模式,它们也很容易在缺省配置中得到支持:

如果没有创建任何模式,那么所有用户隐含都访问 public 模式。这样就模拟了没有模式的时候的情景。这种设置建议主要用在只有一个用户或者数据库里只有几个可信用户的情形。这样的设置也允许我们平滑地从无模式的环境过渡。

你可以为每个用户创建一个模式,名字和用户相同。要记得缺省的搜索路径从$user开始,它会解析为用户名。因此,如果每个用户都有一个独立的模式,那么他们缺省时访问他们自己的模式。如果你使用了这样的设置,那么你可能还想撤销对 public 模式的访问(或者删除它),这样,用户就真的限制于他们自己的模式了。

要安装共享的应用(被所有人使用的表、第三方提供的额外函数等等),我们可以把它们放到独立的模式中。只要记得给需要访问它们的用户赋予合适的权限就可以了。然后用户就可以通过用一个模式名修饰来使用这些额外的对象,或者他们可以把额外的模式放到他们的搜索路径中。

七、移植性

在 SQL 标准里,在同一个模式里的对象被不同的用户所有的概念是不存在的。而且,有些实现不允许你创建和它们的所有者不同名的模式。实际上,模式的概念和用户在那些只实现了标准中规定的基本模式支持的数据库系统里几乎是一样的。因此,许多用户考虑对名字加以修饰,使它们真正由username.tablename 组成。如果你为每个用户都创建了一个模式,这实际上就是PostgreSQL的行为。

同样,在 SQL 标准里也没有public模式的概念。为了最大限度地遵循标准,你不应该使用(可能甚至是应该删除)public模式。当然,有些数据库系统可能根本没有模式,或者是通过允许跨数据库访问来提供模式的功能。如果你需要在这些系统上干活,那么为了最大限度的移植性,应该根本不使用模式。

应用

Salesforce所建置的CRM应用系统是多租户技术在实务应用上成功的案例之一,除此之外还有Salesforce的PaaS就是Force平台及服务,以支持开发人员发展基于Force平台上的应用程序。

在云计算的加持之下,不论是IaaS、PaaS还是SaaS,都可以看到多租户技术的影子。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值