AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 53903
In Process
Richard Beier
Richard Beier
Asked: 2009-08-14 10:47:37 +0800 CST2009-08-14 10:47:37 +0800 CST 2009-08-14 10:47:37 +0800 CST

间歇性地,IIS7 请求卡在 WindowsAuthenticationModule 中

  • 772



我们正在运行一个托管几十个网站的 IIS7 服务器。其中几个网站都是我们开发的同一个遗留应用程序的一部分。这些站点都运行相同的代码并在同一个应用程序池中运行。

在过去的几个月里,大约每月一次,我们发现对该应用程序池的所有请求都开始无限期挂起。发生这种情况时,我们会收到警报并回收应用程序池。之后,这些站点再次开始工作。

这只会影响这个应用程序池 - 不会影响同一服务器上的任何其他应用程序池。有几次,在回收池之前,我查看了工作进程中当前正在执行的请求。它们都显示为在 WindowsAuthenticationModule 中执行。这很奇怪,因为绝大多数应用程序不需要身份验证。有一个小的管理部分使用 Windows 身份验证...但所有其他请求都应该是匿名的。


有没有人知道可能导致这种情况的原因?

这些网站的设置方式有几件不寻常的事情。正如我所提到的,它们都运行相同的代码——多个站点指向同一个物理目录。唯一的区别是主机头绑定。我不确定为什么不只有一个站点包含所有主机标头,但这就是它的工作原理。

在其中几个站点中,相同的物理目录映射到两个级别 - 作为站点的根目录,以及作为站点内的应用程序。因此,如果用户访问http://oursite.com/index.aspx,则映射到 c:\files\oursite\index.aspx。如果用户访问http://oursite.com/foo/index.aspx,它也映射到 c:\files\oursite\index.aspx。我认为有代码可以查看请求 URL 并以不同方式处理这两个请求。

这很奇怪,因为相同的 web.config 最终被解释为站点配置文件,也被解释为站点内的应用程序配置文件。我不知道这是否与身份验证问题有关。


如果我们找不到原因,我们正在考虑一些可以尝试的解决方法:

  • 将管理部分移动到一个单独的站点,并为客户端提供一个新的管理 URL。在其自己的应用程序池中运行该单独的站点。然后在所有其他站点共享的 web.config 中,删除 WindowsAuthenticationModule。这样一来,WindowsAuthenticationModule 中就不应该有挂起的可能性。

  • 尝试在经典管道而不是集成管道中运行所有这些站点。他们在我们的旧 IIS6 服务器上运行良好......

  • (如果我们绝望了)设置一个监视脚本来监视站点并在检测到请求被卡住时自动回收应用程序池。


你怎么看?

谢谢你的帮助,
理查德

iis
  • 1 1 个回答
  • 2748 Views

1 个回答

  • Voted
  1. henrik
    2010-05-25T13:45:20+08:002010-05-25T13:45:20+08:00

    我会尝试右键单击在挂起的应用程序池下执行的 w3wp.exe 进程。右键单击它并选择,创建转储文件。

    任何一个:

    1. 在 Visual Studio 2010 中打开转储文件
    2. 在选项>调试(或类似)下,您可以选择添加符号服务器。添加http://msdl.microsoft.com/download/symbols
    3. 双击挂起的位置并在堆栈跟踪中右键单击并选择下载代码/符号。
    4. 阅读代码,看看它为什么挂起

    或者:

    1. 按照这篇文章安装WinDbg
      • 参考
      • 视频教程
      • 我最喜欢的 Tezz
    2. 做她做的,看看你能不能找到问题
    3. 使用 netsh 激活日志记录以查看发生的 kerberos 令牌请求(我没有尝试过这个 IRL):

      PS C:\> netsh trace show providers | select-string kerberos PS C:\> netsh trace show providers | select-string auth

      ...然后是这样的:

      netsh trace start provider={5BBB6C18-AA45-49B1-A15F-085F7ED0AA90}

    或者:

    1. 聘请顾问。:)
    • 2

相关问题

  • 2003 Server企业版不能运行ASP.NET应用程序?

  • 启用集成 Windows 身份验证时,ASP(经典)在哪个帐户下运行?

  • 是否有一种简单的方法可以生成有关 IIS 中“死”文件的报告?

  • IIS 7 中的 URL 重写

  • 对于 ASP.Net 应用程序,Windows 64 位相对于 32 位的主要优势是什么?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    Windows 中执行反向 DNS 查找的命令行实用程序是什么?

    • 14 个回答
  • Marko Smith

    如何检查 Windows 机器上的端口是否被阻塞?

    • 4 个回答
  • Marko Smith

    我应该打开哪个端口以允许远程桌面?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    kch 如何更改我的私钥密码? 2009-08-06 21:37:57 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve