Cor*_*ger 7 asp.net iis iis-7.5 windows-server-2008-r2
我在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进行配置.据苔丝的博客在这里,还有其他一些原因的AppDomain回收:
- 修改了Machine.Config,Web.Config或Global.asax
- bin目录或其内容已修改
- 重新编译的次数(aspx,ascx或asax)超出了machine.config或web.config中设置指定的限制(默认情况下,此值设置为15)
- 修改虚拟目录的物理路径
- CAS策略已修改
- Web服务重新启动
- (仅限2.0)删除应用程序子目录
该博客文章还提供了有关追踪回收发生原因的信息.对于初学者,尝试查看事件日志(eventvwr.msc)以查看是否有任何详细信息.
您也可以尝试直接调试工作进程.将VS调试器附加到运行代码的w3wp.exe实例,添加断点Thread.Abort
(您可能需要在调试器选项中启用".NET Framework源步进"),并Abort
使用调用堆栈查看源自何处窗口.这不会告诉你它为什么会发生,但至少你会知道是谁在做这件事.
归档时间: |
|
查看次数: |
1609 次 |
最近记录: |