gpt4 book ai didi

asp.net - 如何避免困惑的 ASP.NET Web 应用程序部署?

转载 作者:行者123 更新时间:2023-12-01 17:45:33 26 4
gpt4 key购买 nike

好的,事情就是这样。

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

这个网络应用程序有几个“宇宙”(我们就是这么调用它的)。每个 Universe 都有自己的数据库(当前位于同一服务器上),但它们都共享相同的架构(表、存储过程等)和相同的源/站点代码。

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

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

我不知道如何将各个部分组合在一起

我愿意:

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

我读过有关 MSBuild、M​​S WebDeploy、NAnt 等的内容。但我真的不知道从哪里开始,而且我真的想摆脱这种手动部署。

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

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

任何帮助将不胜感激,

谢谢大家,

问候

最佳答案

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

参见:

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

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

选项 1:

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

选项 2:

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

关于asp.net - 如何避免困惑的 ASP.NET Web 应用程序部署?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2725022/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com