IIS 自動回收導致后臺定時器失效的問題解決
當前位置:點晴教程→知識管理交流
→『 技術文檔交流 』
問題說明: 前幾天做了一個電子郵件定時發送的程序,在實際使用時,發現超過預定完成時間很久,郵件仍未發送完畢。郵件的發送是由 Asp.Net 的后臺線程完成,具體的做法是通過一個全局的 Timer,按照指定的時間間隔逐封發送郵件。因為需要發送的郵件數量較多,并且限定了每小時發送郵件的數量為100封,因而整個發送過程大約需要 20 個小時左右。 解決過程: 在仔細檢測程序后,發現程序本身并沒有問題。于是增加事件跟蹤,從 Windows 的事件查看器中,看到 Asp.Net 應用程序會不定時的關閉,這個時間間隔大約為 1~5 個小時一次。據此懷疑是 IIS 的問題,在網上搜索相關資后得知,IIS 為優化服務器性能,會自動對它認為休眠的應用程序進行資源回收,資源回收將會導致網站應用程序關閉。 可通過下述方式檢驗該結論: 1、首先在 Global.asax 文件的 Application_Start 事件中添加事件記錄,標示應用程序的啟動,如下: System.Diagnostics.EventLog.WriteEntry("Beckman", "應用程序啟動。", System.Diagnostics.EventLogEntryType.Information); 在 Application_End 事件中添加應用程序關閉事件記錄: System.Diagnostics.EventLog.WriteEntry("Beckman", "應用程序關閉。", System.Diagnostics.EventLogEntryType.Information); 2、打開 IIS,選擇 Web 應用程序所在的應用程序集,右擊后點擊“回收”: 3、打開 Windows 系統管理工具中的“事件查看器”,可以看到: 4、找到問題所在,解決的辦法就比較簡單,在發送第一個針對該 Web 應用程序的 Http 請求后,IIS 即會自動啟動 Web 應用程序,那么,我們可以在Web 應用程序關閉后,提交一個請求給該 Web 應用程序,從而開啟關閉的應用程序。程序如下: 在 Application_End 事件中,當 Web 應用程序關閉 5 秒之后,由程序產生一個針對該 Web 應用程序的 Http,IIS 將會再次開啟 Web 應用程序。 備注及說明: 其實對于這個問題,最好的解決辦法并不是基于 ASP.NET,而是另外編寫一個 Windows 服務來執行這種長時間的后臺任務,但是在某些條件下,如客戶租用的是虛擬主機,那么采用 Windows 服務的解決方案顯然不可行,一般說來虛擬主機提供商不會允許安裝 Windows 服務,或者要另行收費,那么本文所敘的方法仍不失為一個好辦法。
該文章在 2021/3/8 12:18:26 編輯過 |
關鍵字查詢
相關文章
正在查詢... |