出错情况
最近在做一个单独线程处理工资条的生成和发送时,出现了一个“另一个进程正在使用此文件,因此该进程无法访问此文件。”的程序错误,造成IIS应用程序池总是死掉。
原因分析
刚开始通过日志分析,发现是子线程多次启动,造成了资源的竞争使用。通过分析代码:
错误的以为是locker锁失效或静态变量掉值,但是通过进一步的日志分析,发现启动子线程的不是同一个进程Id。
解决方案
打开IIS的应用程序池>高级设置
当最大工作进程数>1时,IIS会以“web园”的方式进行工作。因为"web园"会以进程的方式进行请求的处理,多个进程同时处理,所以会导致看到线程多次启动的假象。所以解决方案是将最大工作进程数设置为1,或更改程序进行分配式的方式处理数据。