- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
环境:Windows Server 2003; IIS 6、ASP.NET 2.0.50727
我对我们设置的全新网络服务器感到疯狂(请注意,这个问题不会发生在我们具有相同配置的其他网络服务器上)。第一次加载 ASP.NET 应用程序时,页面会挂起整整一分钟,然后才会在浏览器中显示该页面。加载第一页后,一切运行得非常快。
注1:您可能会说应用程序是第一次编译。但我已经排除了这种可能性。我将跟踪消息放在应用程序中的任何位置,并且所有跟踪消息都在请求页面的一秒钟内运行。因此,该应用程序会立即编译并运行。但是,当应用程序完成渲染页面并打印我的最后一条跟踪消息时,什么也没有发生。在将完成的页面沿 http 传输到用户的浏览器之前,IIS 正在幕后执行一整分钟的操作。
注 2:我们发现,在第一次点击应用程序并且运行正常后,如果我们等待一个小时,就会再次出现延迟。因此,IIS 的缓存中有一些内容会在一小时后清除,并导致我们的网站再次停止运行。
注 3:在每次测试之间,我们停止/启动 IIS,以强制其在加载应用程序时挂起。
注释 4:我们观察任务管理器以查看 IIS 是否处于峰值状态并占用大量资源来处理某些内容。但事实并非如此。在浏览器显示页面之前,我们确实看到了非常快的峰值,达到 50%,但在之前的 60 秒内,服务器上的使用率只有 1%。
注释 5:在另一个测试中,我创建了一个 HelloWorld.html 页面,这不会导致 IIS 挂起。因此,它与第一次通过 http 发送渲染页面时调用 ASP.NET 库有关。此外,由于应用程序已经编译并立即运行,因此只是 ASP.NET 将呈现的页面发送到用户浏览器的部分导致了延迟。
有什么想法吗?我们在这里是一个损失。我们所有其他网络服务器都以相同的方式设置并且工作正常,但这是一个新安装。那么一定有一个配置设置被遗漏了或者可能需要安装一些东西?
谢谢
布莱恩
最佳答案
如果您有权访问服务器,请确保应用程序池回收实际记录到事件日志中
cscript adsutil.vbs 获取 w3svc/AppPools/DefaultAppPool/LogEventOnRecycle
您可以将其设置为记录所有内容cscript adsutil.vbs 设置 w3svc/AppPools/DefaultAppPool/LogEventOnRecycle 255
然后检查是否有任何回收。
应用程序初始化、创建工作进程、线程、加载应用程序域和所有引用 dll 可能需要一些时间,这很正常,但 1 分钟的延迟可能是其他原因。
尝试在服务器上预编译应用程序,看看是否有帮助aspnet_compiler -m/LM/W3SVC/[站点 ID]/Root/[您的应用程序名称]
如果您想深入了解,可以检查事件跟踪 ETW。
您可以在这里找到更多信息 Troubleshooting appdomain restarts and other issues with ETW tracing
我还会使用 procexp 检查 w3wp.exe 是否有 TCP 连接超时,或者使用 Procmon 检查其他线索。
如果您有使用windbg的经验,那么您可以向应用程序发出请求,然后快速将调试器附加到进程
windbg -p [process id of the app pool]
.loadby sos mscorwks
g
然后从那里拿走它。如果出现异常、进程崩溃等,您应该能够捕获它......
一旦我们遇到了像这样奇怪的服务器问题,并且 .NET 重新安装解决了问题,但仍然不确定罪魁祸首是什么。
关于asp.net - iis 启动延迟与 aspx 页面,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12204311/
当我查看 IIS 日志文件时,我可以在一天中的不同时间看到标题行被写入日志文件。我唯一一次看到这种情况发生是在 IIS 重置时;或启动。 例如下面的标题行; #Software: Microsoft
有谁知道为什么以下 web.conig 更改不起作用: 在我添加 javascript 文件后仍然没有被压缩(gzip)。我折腾了几天,因为一开始我真的不知道问题是
目前,我们所有的网络应用程序都将其应用程序池标识设置为 ApplicationPoolIdentity。现在,当一个应用程序需要访问某些服务器上的某些资源时,比如添加/读取某些文件,该应用程序会在代码
在 IIS(特别是 6.0)中,在“主目录”选项卡下,如果我更改本地路径,是否会导致 IIS 重新启动或应用程序池回收? 相关的,是否有概述 IIS 元数据库的哪些更改将触发重新启动或应用程序池回收的
只要更改了任何 web.config 文件,AFAIK IIS 就会重新启动。 我创建了自己的配置文件(my.config,层次结构略有不同)。是否有可能让 IIS 自动(自动神奇地 :))重新启动,
你好, 我正在寻找 IIS 日志中列出的浏览器条目列表,以帮助识别访问我们网站的不同版本的浏览器。也许没有一个列表,而是一个应该用来识别不同浏览器及其版本的算法。 请注意,我不是在寻找日志分析器,而是
我想知道上次重新启动 iis 是什么时候。 IIS 是否保留了此日志,我在哪里可以找到此日志? 谢谢 最佳答案 打开事件查看器,导航到“Windows 日志”->“系统” 在右侧的“操作” Pane
在全新安装的带有 IIS 7 的 Windows Server 2008 R2 上,它会在 C:\inetpub\wwwroot 中创建一个默认网站。 .我确信对于存储网站文件的好位置有很多主观意见,
我已按照 this question 中的说明在 IIS 中实现动态内容压缩。 . 当我发送请求时,我看不到响应被 gzip 压缩的任何证据: IIS版本为7.5 有什么明显的我应该检查以解决此问题吗
这是场景: 服务器 A 托管“主”应用程序 (www.example.com) 服务器 B 托管支持应用程序 (b.example.com) 它们通过 192.* 地址在内部相互连接,并且都可以通过
是否有任何替代 IIS 管理 UI 可用于从程序重置 IIS?.. 现在我们已经创建了一个批处理文件,如果 iis 重置并每小时安排一次...... 我只是想要一些东西,这样我们就不能重置 iis..
我的 Windows Server 在 IIS 7.5 上运行 Web 应用程序。 我想知道为什么 IIS 应用程序池使用大量内存。 请参阅我从服务器捕获的屏幕截图。 在名为 TEST 2.0(.NE
我在 IIS 7.5 上运行的 ASP Classic 站点上收到服务器错误。 我将“向浏览器发送错误”设置为 True ,但是我仍然收到以下错误屏幕: 最佳答案 IIS 正在劫持您的经典 ASP 应
我正在尝试通过IIS上的反向代理连接到websockets服务器(websockify)。 IIS和Websockets服务器位于同一台物理服务器上(Windows Server 2012 R2,II
我需要让我的开发机器从本地机器商店读取证书 为此,我需要运行winhttpcertcfg.exe并指定我要提升的帐户 该帐户用于IIS表示什么? (对于IIS,它将是IWAM_MachineName)
我正在阅读特定命令(SET-WEBCONFIGURATIONPROPERTY),但出现"is not recognized as a cmdlet"错误。给我的建议是,即使我使用的是SharePoin
我已经为 IIS8 安装了静态和动态压缩并启用了它。 当我的CPU性能100%时,我的GZIP IIS不工作,为什么? 我可以清楚地看到 GZIP 没有在 Live HTTP header 中运行。我
我已经从官方镜像(https://hub.docker.com/r/microsoft/iis/)运行了IIS 在Windows Server 2016上 有什么方法可以从IIS管理器连接到该IIS,
你好, 如果 iis 未运行,我想编写一个状态为的代码。 最佳答案 从命令行启动 IIS: iisreset /start 从命令行停止 IIS: iisreset /stop 重新启动(停止和启动)
我已经为 IIS8 安装了静态和动态压缩并启用了它。 当我的CPU性能100%时,我的GZIP IIS不工作,为什么? 我可以清楚地看到 GZIP 没有在 Live HTTP header 中运行。我
我是一名优秀的程序员,十分优秀!