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