3

好的,事情就是这样。

我正在 ASP.NET 4.0 和 SQLServer 2005 下开发一个现有的(它开始是一个 ASP 经典应用程序,所以你可以想象:P)Web 应用程序。我们是 4 个使用 SQL Server 2005 Express 本地实例的开发人员,拥有源代码-代码和 Visual Studio 数据库项目

这个 webapp 有几个“宇宙”(这就是我们所说的)。每个 Universe 都有自己的数据库(目前在同一台服务器上),但它们都共享相同的模式(表、存储过程等)和相同的源/站点代码。

所以手动部署真的很烦人,因为我必须部署源代码,然后在每个数据库上手动运行 sql 脚本。我知道手动部署会导致问题,所以我正在寻找一种自动化的方法。

我们最近创建了一个 Visual Studio 数据库项目来管理架构并生成具有不同目标的差异架构脚本。

我不知道如何把这些碎片放在一起

我想:

  1. 有一种方法可以将“同步”部署到目标服务器(谢天谢地,我拥有对服务器的完全 RDC 访问权限,因此我可以在需要时进行安装)。对于“同步”部署,我的意思是我不想完全部署整个应用程序,因为它有很多文件,我只想部署那些新的或更改的文件。
  2. 为每个数据库目标生成 diff-sql 更新脚本,并将其组合成一个脚本。为此,我应该在某处列出一些数据库名称。
  3. 复制站点文件并以简单且自动化的方式执行生成的 sql 脚本。

我已经阅读了有关 MSBuild、M​​S WebDeploy、NAnt 等的信息。但我真的不知道从哪里开始,我真的很想摆脱这种手动部署。

如果有比我列举的更好、更简单的方法,我会很高兴阅读您的选择。

我知道这不是一个非常具体的问题,但我已经用谷歌搜索了很多,似乎我不知道该怎么做。我从未使用任何自动化工具进行部署。

任何帮助将不胜感激,

谢谢你们,

问候

4

1 回答 1

1

你听说过多租户这个词吗?可能值得一看,看看它是否适用于你的“多元宇宙”,特别是如果一个宇宙永远不会被另一个宇宙访问……

看:

http://en.wikipedia.org/wiki/Multitenancy

http://msdn.microsoft.com/en-us/library/aa479086.aspx

更新:

如果每个客户端(或租户)的应用程序和数据库都相同,我相信有些应用程序可能有助于提供与 SaaS 应用程序相同的代码/数据库?即顶部的另一个应用程序/配置层可以处理部署等?

我认为这些被称为平台即服务 (PaaS) 应用程序:

见:http ://en.wikipedia.org/wiki/Platform_as_a_service

在您的情况下,多租户可能是可能的,具体取决于客户的安全要求,需要一些工作(或大量工作):

选项1:

您可以使用应用程序的一个实例,即一次部署站点并为每个客户端连接到不同的数据库。您需要通过 URL 区分每个客户端以隔离内容/数据,为每个客户端设置一个连接字符串等。(这会将您的站点部署减少到一个部署)

选项 2:

您可以创建应用程序的单个实例并使用单个数据库。您需要在每个表中添加“TenantID”并调整所有代码以接受 TenantID 以确保数据安全/隔离。同样,您需要根据 URL 检测/区分租户,以设置用于每个数据库调用的会话的 TenantID。(这会将您的站点和数据库部署减少到一个)

于 2010-04-27T21:38:00.150 回答