.NET Core 部署IIS无法启动Hangfire方案
【導讀】不知道是否有童鞋遇到過將.NET Core部署到IIS上時,但Hangfire無法啟動,自然而然也就導致作業無法良好運行的問題,本文給出兩個方案,不知是否有完美解決方案,若有,請于留言中給出,謝謝。
Hangfire部署IIS
相信有一部分童鞋在.NET Core上利用Hangfire來進行作業計劃,無論是一觸即發,還是延遲,抑或是周期Hangfire都能很好的支持,但是若將Hangfire應用于實際生產環境時,我們會發現存在很多問題,這些問題只有實踐過后才能體會到各種坑,但更深入的資料網上并沒有,只能靠經驗或依托源碼摸索。
配置什么的就不過多廢話,我們實現一個很簡單的Hangfire周期作業,然后將一段字符串輸入到文本上,如下周期作業:
RecurringJob.AddOrUpdate(()?=>?File.WriteAllLines(Path.Combine(AppContext.BaseDirectory,?"hangfire-demo.txt"),?new[]?{?"Recurring"?}),Cron.Minutely());要將.NET Core寄宿在IIS運行除了安裝必須的runtime外,還需安裝對應版本的host-bundle模塊,這里以.NET Core 3.1為例,所以安裝名為【dotnet-hosting-3.1.0-win】的host-bundle,至于原因請自行察看官方文檔
緊接著我們打開IIS,創建.NET Core的無托管應用程序池,繼而創建網站,如下圖所示
然后我們就等啊等,等到花兒都快謝了,最終我們會發現過了幾分鐘后然鵝并沒有在如下圖文本中輸出字符串,你說氣人不
IIS啟動Hangfire方案
首先我們在web.config里打開.NET Core默認日志輸出,將該屬性設置為ture即可,如下圖所示
然后手動訪問下網站,接下來我們就可以看到日志文件
請客官稍等片刻,緊接著就啟動了Hangfire后臺服務并輸出了字符串到文件中
就是這樣,必須手動訪問下網站才能在IIS上啟動Hangfire,Hangfire本就作為后臺作業服務去啟動業務作業,現在反過來還得手動鞭策一下才能啟動,有意思。
那么究竟是什么原因導致必須手動訪問網站才能啟動Hangfire呢?
那我們是否可以理解為網站的啟動并不會使.NET Core程序啟動,換言之也就是不會執行startup,只有第一次訪問時才會執行呢?
那么我們是否通過什么方式使得網站啟動時,程序也進行了執行(即執行startup呢)
唯一能想到的則是.NET Core應用程序池,所以接下來我們嘗試,當我們發布程序到IIS時首先將.NET Core應用程序池停止,創建完網站后再將該程序池啟動,如下:
此時我們將發現在啟用了.NET Core默認文件日志輸出后,將會自動如上生成日志文件,從而很好的啟用了Hangire后臺作業服務。
綜上所述在IIS上想要啟動Hangfire作業服務,要么手動訪問下網站,要么在網站啟動后再啟動.NET Core無托管應用程序池。
以上純屬我個人的猜測和分析,若有錯誤之處,還請批評指正,謝謝。
總結
以上是生活随笔為你收集整理的.NET Core 部署IIS无法启动Hangfire方案的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 旧 WCF 项目迁移到 asp.net
- 下一篇: 初识ABP vNext(3):vue对接