观察进程管理器,发现:
W3WP的线程数,一直在变化,一会增加一个高峰值,重新增加一个W3WP进程,之前的进程过一会就自动关闭,一会又恢复正常。
这说明网站,在不断的死亡、重启。到底是哪里的问题呢?应该还是系统自己的问题了。但是它自身的版本并没有问题,为了确定这一点,我也试了之前稳定的版本,同样出现此类问题。最后,是否是系统中调用的第三方服务,将整个系统给拖死了呢?
罪魁祸首:经过检查,果然是由于程序中实时调用了一个服务,由于此服务已经停止,请求无果,出现了死锁。
教训:
<1>最大大限度保证系统与第三方服务的稳定、安全,并在请求过程中做超时判断、消息分级处理。
<2>遇到问题,首先应全面分析系统的问题可能性,因为系统本身的运行环境一般都是固定不变的,出现问题的可能性很小。
有的时候在写程序的时候,如果出了问题,首先应该怀疑自己的思路、代码哪里出了问题,而不应该去怪罪IDE或者OS出了什么BUG。这样你就少走很多弯路。
通过上边的介绍,我出现此问题的原因是:(在此贴出备注一下)

首选我代码里没有用到加锁代码(例如:Application.Lock(), Application.UnLock()等);
其次在此问题之前,没有出现过此问题,并且良好运行过很长时间;
最后发现,由于我代码里调用c/c++ DLL, 而DLL里要链接网关服务,然后网关服务此时没有开启,从而出错,开启DLL需要的网关服务,就可以了。









