什么是多租户?
“软件多租户是指一个软件体系结构,其中一个软件实例在一个服务器上运行,并为多个租户提供服务*租户是一组共享具有软件实例特定权限的公共访问权限的用户。 架构中,软件应用程序旨在为每个租户提供一个包含其数据*,配置,用户管理,租户个人功能和非功能属性的实例共享*多租户与多实例架构形成鲜明对比,其中独立的软件实例运行 代表不同的租户“(维基百科),简而言之,多租户是一种用于创建SaaS(软件即服务)应用程序的技术。
数据库和部署体系结构
有一些不同的多租户数据库和部署方法:
1、多个部署 - 多个数据库
实际上这不是多租户,但是如果我们为每个客户(租户)运行一个具有独立数据库的应用程序实例,则可以在一台服务器上为多个租户提供服务。我们只需确保应用程序的多个实例在相同的服务器环境中不会相互冲突。
对于不是被设计为多租户的现有应用来说,这也是可能的。由于应用程序不知道多租户,创建这样的应用程序更容易。然而,这种方法存在设置,使用和维护问题。
2、单一部署 - 多个数据库
在这种方法中,我们在服务器上运行应用程序的单个实例。我们有一个主(主机)数据库来存储租户元数据(如租户名和子域)和每个租户的单独数据库。一旦我们确定了当前的租户(例如,从子域或从用户登录表单),那么我们可以切换到该租户的数据库来执行操作。在这种方法中,应用程序应该在一定程度上被设计为多租户,但大部分应用程序可以保持独立。我们为每个租户创建和维护一个单独的数据库,这包括数据库迁移。如果我们有许多专用数据库的客户,则在应用程序更新期间迁移数据库模式可能需要很长时间。由于每个租户都有独立的数据库,我们可以将数据库与其他租户分开备份。如果租户需要,我们也可以将租户数据库迁移到更强大的服务器上。
3、单一部署 - 单个数据库
这是最理想的多租户体系结构:我们只将具有单个数据库的应用程序的单个实例部署到单个服务器上。我们在每个表(对于RDBMS)中都有一个TenantId(或类似的)字段,用于隔离租户的数据。
这种类型的应用程序易于安装和维护,但难于创建。这是因为我们必须防止租户读取或写入其他租户的数据。我们可以为每个数据库读取(选择)操作添加一个TenantId过滤器。我们也可以在每次写入时检查它,看看这个实体是否与当前的租户有关。这是乏味和容易出错的。但是,ASP.NET Boilerplate通过使用自动数据过滤来帮助我们。如果我们有许多拥有大量数据集的租户,这种方法可能会有性能问题。我们可以使用表分区或其他数据库功能来克服这个问题。
4、单一部署 - 混合数据库
我们可能希望将租户正常存储在单个数据库中,但可能希望为所需租户创建单独的数据库。例如,我们可以将拥有大数据的租户存储在自己的数据库中,但将所有其他租户存储在单个数据库中。
5、多部署 - 单/多/混合数据库
最后,我们可能希望将我们的应用程序部署到多个服务器(如Web场)以获得更好的应用程序性能,高可用性和/或可伸缩性。这与数据库方法无关。
我所采用的是单部署多数据库的形式,主要是为了数据隔离,我也好维护。但是在多数据库的时候老是抛出错误 (图1)。最后发现网上说开启MSDTC服务。
未开启MSDTC服务
图1 报错
系统开启MSDTC 服务后、然后使用租户登录、发现还是有问题!
最后问了搞.NET 朋友,说是配置 DTC 安全配置。
- 展开-> "应用程序服务器” -> “工具” -> “组件服务”->右键“本地DTC”
- 选择“本地DTC”的“安全选项卡”,做如下设置:
DTC
(1)选中“网络DTC访问”
(2)在客户端管理中选中“允许远程客户端”“允许远程管理”
(3)在事务管理通讯中选“允许入站”“允许出站”“不要求进行验证”
(4)保证DTC登陆账户为:NT Authority\NetworkService
(5)单击"确定"。这样将会提示您"MS DTC 将会停止并重新启动。 所有的依赖服务将被停止。请按'是'继续"。单击"是"继续。
3.关闭网络防火墙(或者开放相应的端口135或用打开服务启动TCP/IP NetBIOS Helper服务)