为什么工作线程使我的ASP.NET生成器在睡眠期间遇到ThreadAbortException?

前端之家收集整理的这篇文章主要介绍了为什么工作线程使我的ASP.NET生成器在睡眠期间遇到ThreadAbortException?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我在 Windows Server 2008,IIS 7.5上运行的ASP.NET应用程序中生成一个工作线程.这个工作线程做的第一件事就是睡眠N秒,然后它才能真正起作用.在睡眠期间,捕获一个ThreadAbortException.

你能解释一下这种行为,并且你的奖励点指向我可以用来调整行为的任何IIS / ASP.NET设置.

编辑:更多信息.捕获ThreadAbortException的建议帮助我解决了这个问题,谢谢.根据我学到的东西,我完全重写了这个问题的措辞,但同样的问题,为什么这个工作线程在睡眠中会中止?

解决方法

ThreadAbortException发生在你的工作线程上,因为有人在其上调用Thread.Abort,所以它可能与你的工作线程没有直接关系,而是一些外部原因.您应该检查的第一个地方是您自己的代码,您可以执行任何线程管理或中止.否则,对于IIS,这可能是由于工作进程(w3wp.exe)或应用程序池或AppDomain被回收.

回收可能是由于应用程序池的空闲超时设置,定期计划的回收或内存/ cpu使用触发器.这些可通过服务器资源管理器中的IIS配置管理器(在Win 2K8上)或仅运行inetmgr.exe进行配置.根据Tess的博客here,AppDomain回收还有很多其他原因:

  • Machine.Config,Web.Config or Global.asax are modified
  • The bin directory or its contents is modified
  • The number of re-compilations (aspx,ascx or asax) exceeds the limit
    specified by the
    setting in machine.config or
    web.config (by default this is set to
    15)
  • The physical path of the virtual directory is modified
  • The CAS policy is modified
  • The web service is restarted
  • (2.0 only) Application Sub-Directories are deleted

博客文章还提供了有关追踪回收发生原因的信息.对于初学者,尝试查看事件日志(eventvwr.msc)以查看是否有任何详细信息.

您也可以尝试直接调试工作进程.将VS调试器附加到运行代码的w3wp.exe实例,在Thread.Abort上添加断点(您可能需要在调试器选项中启用“.NET Framework源步进”),并查看Abort源自何处使用调用堆栈窗口.这不会告诉你它为什么会发生,但至少你会知道是谁在做这件事.

猜你在找的asp.Net相关文章