- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们有一个在 Azure 云服务 Web 角色中运行的 ASP.NET MVC 应用程序。 MvcApplication.Application_Start()
中有很多启动代码,其中包括数据库初始化等,这可能需要几分钟或更长时间才能运行。
有时,当角色实例启动时(无论是在部署时还是在重新启动后),应用程序首次无法启动。我们可以从日志中看到 Application_Start
触发,通过一定的方式,然后从头开始。重复此过程几次后,应用程序通常会完成其启动例程并开始处理请求,但有时它会进入看似永无休止的循环,对此唯一的解决方案是重新启动或重新镜像角色实例。
我们没有看到记录任何错误,并且 Application_End
根本没有触发。 Serilog 的 HttpRequestIdEnricher每次 Application_Start
触发时都会记录不同的请求 ID,表明每次都有一个新的 HttpContext.Current
。我在本地运行时从未见过这种行为,只在 Azure 中见过。
有什么想法吗?
此行为似乎仅在网站上发出多个请求时才会发生。当生产中的角色实例重新启动时,最常见(并且令人恼火)会发生这种情况; UAT 环境通常启动良好,但我可以通过在不同的浏览器选项卡中发出多个请求来引发此问题。我还尝试实现类似 this 的东西- 使用 WebRole.OnStart
ping Web URL 以确保网站在退出之前正在运行 - 但这只能确保网站永远不会出现。
所以我的猜测是 IIS 负责:当 Application_Start 正在进行时收到新请求时,它似乎正在重新启动应用程序而不是让原始请求完成。
最佳答案
我似乎已将此问题归结为 IIS 应用程序池配置中的一两个设置。
我最初认为启动时间限制
是最有可能的罪魁祸首,并尝试将其设置为 240 秒(因为我们的应用程序通常需要 2-3 分钟才能启动),但问题仍然存在。随后我还将 Ping 最大响应时间
更改为 240 秒,这似乎已经解决了这个问题。
当启动陷入循环时,连续启动之间通常(并非总是)有 2 分钟的间隔,因此我假设 IIS 等待 30 秒(默认 Ping 周期
),然后在重新启动工作进程之前,触发请求并等待 90 秒以获取响应。
此 Powershell 代码位于 Web 角色启动时运行的脚本中,用于配置相关设置:
Import-Module WebAdministration
Get-ChildItem IIS:\AppPools | ForEach-Object {
$appPool = "IIS:\AppPools\" + $_.Name
$startupLimit = New-TimeSpan -Minutes 4
Set-ItemProperty $appPool -Name processModel.startupTimeLimit -Value $startupLimit
Set-ItemProperty $appPool -Name processModel.pingResponseTime -Value $startupLimit
}
应该可以使用 Microsoft.Web.Administration.ServerManager
执行相同的操作,但我没有尝试过。
关于asp.net-mvc - Azure Web 角色启动时 Application_Start 循环,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41017091/
我研究了很多但一无所获...... Application_Start 事件在发布站点时未触发。但是它在本地主机上运行良好。发布后,我在 Bin 文件夹中获得了 App_global.asax.dll
我在 global.asax 文件的 application_start() 方法中编写了一些代码。当我在 IIS 服务器上部署我的应用程序时,它不会被调用。当我在 .NET 框架中运行代码时,它是可
我们目前使用这行代码来获取 Application_Start 事件中的当前应用程序 url。 string sApplicationURL = HttpContext.Current.Request
我有一个正在开发的 ASP.NET MVC(测试版)应用程序,但我无法确定是我做错了什么,还是我的 Application_Start 方法在 Global.当我尝试调试应用程序时,asax.cs 实
我有一个在 asp.net MVC 2 上制作的应用程序,它位于我电脑上的 IIS 7.5 上,我尝试对其进行分析,发现 Application_Start 被调用多次, 有人知道为什么会发生这种情况
我正在使用 sitecore 7.5,我需要在 application_start 中添加新路由以便在 ajax 调用中使用它,但是当我运行应用程序时,sitecore 似乎将路由作为内容项处理,请提
我必须处理用 .NET Framework 1.1 编写的遗留 ASP.NET 应用程序。在检查应用程序代码时,我发现了有趣的部分。应用程序在 Application_Start 事件处理程序 (Gl
是否可以在 Application_Start 上创建一个可以在所有 Controller 中使用的类实例? 我希望能够创建例如: var globalHelper = new LoadsStuff(
我希望将这篇文章塑造成一个合法的 StackOverflow 问题,因为我真的很想深入了解这种情况,但我绝对可以看看它是否过于本地化或被视为“意见”。 这是我的场景:当我加载我的网络应用程序时,我从数
我一直在尝试在全局 asax 的 Application_Start 事件上获取我的项目的应用程序路径我可以在未路由的页面上使用 server.mappath 但是当我在路由页面上时我得到新的虚拟pa
我正在使用 IIS7.5 强制我的 Web 应用程序自动加载 (startMode="AlwaysRunning"),现在我想预加载我的缓存数据。不过我有点困惑,因为两种方法看起来是一样的: 在 gl
我无法使用 获取 Application_Start 中的当前物理路径 HttpContext.Current.Request.PhysicalApplicationPath 因为当时没有Reques
我不明白为什么在我的 ASP.NET 应用程序启动时 Application_Start 事件会被调用两三次? Application_End 不在 Application_Start 调用之间调用。
在我们的 Application_Start事件处理程序我们正在执行一些由于文件锁定问题而间歇性失败的操作。在这种情况下,我们希望将应用程序返回到“未启动”状态。 我的意思是,用户将看到一个错误页面,
问题: Application_Start 事件没有在我的包含 TCP 端点的 WCF 服务中触发。 背景: 我正在尝试从控制台应用程序访问该服务。如果服务尚未启动,则调用将失败,因为 Applica
我正在调试一个初始页面加载缓慢的 ASP.NET 2.0 应用程序。 通过添加日志记录,我发现 Application_Start事件在启动时触发两次,两个事件之间有很短的延迟。 Session_St
... Application_Start 方法是否会为下一个请求再次运行? 它是否取决于 ASP.NET 版本、托管服务器版本和/或其他上下文? 我试图确定在那里加载关键程序集是否是一件好事。例如,
我目前正在更改我们的数据库部署策略以使用 FluentMigration,并一直在阅读如何运行它。有些人建议它可以从 Application_Start 运行,我喜欢这个想法,但其他人说不,但没有具体
我有一个应用程序在我的开发工作站上运行良好,但在将应用程序部署到实时环境时失败。看来 Application_Start 没有在实时环境中被调用。 最佳答案 我可以通过删除测试服务器上网站根目录中的
我有一个 ASP.NET Web 应用程序开始显示一些非常奇怪的行为。下面是一些示例代码: // in Bar.cs public class Bar { public static Baz
我是一名优秀的程序员,十分优秀!