【问题标题】:What timeouts govern worker process shutdown when stopping an application pool停止应用程序池时,哪些超时控制工作进程关闭
【发布时间】:2021-07-05 18:00:29
【问题描述】:

我有一个在 IIS 中运行的 ASP.NET (.NET Framework) 站点。该站点有一个长时间运行的后台进程,当应用程序池作为拆除活动 VM 的一部分而停止时,我希望 w3wp 进程继续运行,直到后台进程正常关闭(这可能需要很长时间) .

我们利用自定义 IRegisteredObject 插入 ASP.NET 关闭;在后台进程关闭之前,我们的代码不会从 Stop(true) 调用返回。

当我们停止应用程序池时,我们在日志中看到 Stop(false) 被调用,然后 Stop(true) 像我们预期的那样在 30 秒后被调用。但是,在 Stop(true) 返回之前,IIS 只是在杀死工作进程。此终止发生在初始 Stop(false) 调用后五分钟。我们想延长这个超时时间。

在 IIS 本身中,我们有 App pool->Process Model->Shutdown Time Limit to 1000s。将此值降低到 5 分钟以下可以使杀戮更快发生,但将其提高到 5 分钟以上并不能阻止 5 分钟的杀戮。

是否有其他一些超时设置来控制此关闭?是否可以超过 5 分钟?

【问题讨论】:

  • Web 应用程序中长时间运行的进程不是一个好主意。您是否考虑过将该功能提取到 Azure 函数/AWS Lambda(在云中)或 Windows 服务(本地)?
  • @mason 在写这个问题时,我试图将情况简化为不熟悉特定上下文和应用程序的人容易理解的情况,但这并不完全是更复杂的情况我加入了。我知道还有其他方法可以运行长时间运行的进程,但我特别想更深入地了解应用程序池停止行为。

标签: asp.net .net iis


【解决方案1】:

关闭时间限制提示使旧工作进程最多运行指定的秒数。如果所有请求都在该时间之前完成,那么它将提前关闭。这就是为什么你将值降低到 5 分钟以下以使杀戮更快发生。

而且最大shutdown timelimit seconds好像是4294967,这个是5多分钟,但是如果没有足够的空闲内存,会导致不超过5分钟。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2023-03-02
    • 1970-01-01
    • 1970-01-01
    • 2018-07-17
    • 2015-11-10
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多