我正在处理的 Windows 服务存在一个非常奇怪的问题,我想了解它为什么会发生。
该服务每 5 分钟循环一次,然后在该循环内循环遍历包含编号的 Web 服务 URL 的键,例如:
<add key="URL.1" value="http://dummy1.com/Service.asmx"/>
<add key="URL.2" value="http://dummy2.com/Service.asmx"/>
<add key="URL.3" value="http://dummy3.com/Service.asmx"/>
执行此检查的代码是:
If String.IsNullOrEmpty(AppSettings("OM." & intCount & ".Name").ToString) Then
当它击中一个不存在的键时,将引发异常并且服务停止并等待 5 分钟,直到下一个循环。
这通常效果很好,但每隔一两周,Windows 服务就会在那条线上崩溃,没有任何异常。应用程序日志在该行之前有一行,但之后没有任何内容,没有一个 Try Catches 被命中(主要是捕获基本的“异常”类)。
在 Windows 的事件日志中如下:
Faulting application name: MyService.exe, version: 1.1.2.0, time stamp: 0x4fa22a24
Faulting module name: KERNELBASE.dll, version: 6.1.7601.17651, time stamp: 0x4e211319
Exception code: 0xe053534f
Fault offset: 0x0000b9bc
Faulting process id: 0x%9
Faulting application start time: 0x%10
Faulting application path: %11
Faulting module path: %12
Report Id: %13
奇怪的是,这行代码每天至少执行 300 次,持续至少一周,这大约是在导致应用程序完全崩溃之前的 2000 次。
任何想法为什么会发生这种情况?我已将那行代码更改为不依赖异常,并且它已经工作了一周没有崩溃,所以可能与太多异常有关 - 可能导致堆栈溢出?