有没有办法让 IIS 尽快将请求转储到其日志文件?
语境
我遇到了一个问题,即我向 IIS 发出的请求被处理和实际记录到 IIS 日志之间存在很长的延迟。延迟时间可能在 20 秒到 60 秒之间。
一些关键点:
- 一旦请求出现在日志文件中,它就会显示请求发生的实际时间,
- 报告显示请求处理速度最快仅需 350 毫秒,
- 在 IIS 请求日志中,请求也没有“卡住”
- 请求很快被浏览器完全处理
- 我注意到,在生产中,无论是稍微繁忙还是完全不繁忙,Windows Server 2012(IIS 6.2 build 9200)
- 在我的开发主机中也有同样的行为,一点也不忙,Windows 10(IIS 10.0.19041.1)
- 生产是在亚马逊存储中进行的(我无法说出他们使用的确切技术,我相信它源自 SSD)
- 本地存储是SSD盘
- 如果我监视同一磁盘/文件系统中的文件,则对文件的更新会立即反映到显示屏上(最多,如果有的话,延迟 1 秒)
我尝试过的一些方法
我尝试过tail -f
或不断重复tail
命令,以及使用“查看 > 监控 (tail -f)”模式的 Notepad++。所有这些都同时更新文件内容,遵循有点随机但总是很长的延迟。
从我在 StackOverflow 上发布的这个问题的副本(题外话)中,Xudong Peng 建议我尝试从 IIS 服务器范围的配置文件(或IIS 管理器顶级节点(计算机)>配置编辑器> )进行flushByEntryCountW3CLog设置。它确实使日志记录间隔发生了变化,但情况更糟。现在感觉它每分钟都在被转储,所以我将其恢复为 0。%WinDir%\System32\Inetsrv\Config\applicationHost.config
sites.applicationHost/sites/siteDefaults/logFile
关于上述主题,我还确保<site>
我测试的特定内容不会覆盖sitesDefault/logFile/flushByEntryCountW3CLog
in applicationHost.config
。还回收了应用程序池(因此网站也被回收了),设置肯定会生效。仍然是相同的“行为”变化,似乎更糟。
看起来,即使缓冲区(该设置的 64k)未填满,它也大约每分钟都会被转储一次。设置为该1
值时,转储发生在 1 到 2 分钟之间。
我找不到有关“日志文件缓冲区”的任何其他设置(因此 IIS 会在将日志条目“转储”到文件之前填充一个缓冲区)。
底线
这是正常的吗?处理 IIS 日志的每个人都需要花时间检查日志中的请求,或者是否有办法(至少暂时)让 IIS 尽快将请求转储到日志文件中?