gpt4 book ai didi

c# - 是否可以在零停机的情况下部署企业 ASP.NET 应用程序和 SQL 架构更改?

转载 作者:IT王子 更新时间:2023-10-29 04:43:49 26 4
gpt4 key购买 nike

我们有一个庞大的 ASP.NET Web 应用程序,需要在零或几乎零停机时间的情况下部署到 LIVE。让我指出我已经读过the following question/answers但不幸的是,它并没有解决我们的问题,因为我们的架构有点复杂。

假设目前我们有两个 IIS 服务器响应请求,并且都连接到同一个 MSSQL 服务器。该解决方案似乎是小菜一碟,但这并不是因为我们必须不时应用主要的架构更改。由于规模巨大,一个简单的数据库备份大约需要 8 分钟,这已经变得 Not Acceptable ,但出于安全原因,在每次新部署之前都必须这样做。

我想请求您的帮助,以尽可能缩短部署时间。如果您对不同的架构有任何好主意,或者您可能使用过可以帮助我们的工具,那么请不要害羞并分享信息。

目前,我们提出的最佳想法是购买另一台 SQL 服务器,将其设置为原始数据库的副本。从负载均衡器,我们会将所有新流量路由到两个 IIS 网络服务器之一。当第二个网络服务器没有正在运行的 session 时,我们可以部署新代码。现在是困难的部分。在这一点上,我们将网站离线,取消两个 SQL 服务器之间的复制,这样我们就可以直接获得处于一致状态的数据库快照(8 分钟中节省 7.5 分钟)。最后,我们将更新主 SQL 服务器上的数据库架构,并在将第二个网络服务器升级到新版本时通过更新后的网络服务器路由所有流量。

也请分享您对此解决方案的看法。我们能否以某种方式设法消除网站离线的需要?拥有庞大Web应用的蓝筹公司如何部署?

非常欢迎任何想法或建议!购买新的硬件或软件真的不是问题——我们只是错过了突破性的想法。预先感谢您的帮助!

编辑 1(2010.01.12):
还有一个要求就是要杜绝人工干预,所以其实我们是在寻找一种可以自动化应用的方式。

让我提醒一下需求 list :
1.数据库备份
2a.网站部署
2b.更新数据库架构
3. 更改为更新的网站
4(可选):如果出现严重问题,可以轻松恢复到旧网站。

最佳答案

首先,您可能不知道“point in time restore”这个概念。总而言之,如果您正确地备份了您的事务日志,备份需要多长时间并不重要 -- 您始终能够恢复到任何时间点。您只需还原上次备份并重新应用此后的事务日志,就可以还原到部署点。

我倾向于推荐的是在不同的网站定义上重新安装该网站,并配置一个“死”主机 header ——这是您的登台网站。制作一个脚本,它一次运行您的数据库更改(在事务中),然后在实时站点和暂存站点之间翻转主机 header 。

关于c# - 是否可以在零停机的情况下部署企业 ASP.NET 应用程序和 SQL 架构更改?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4603873/

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