執行後臺任務的利器——Hangfire

Hangfire是一個開源且商業無償使用的工具函數庫。可讓你很是容易地在ASP.NET應用(也能夠不在ASP.NET應用)中執行多種類型的後臺任務,而無需自行定製開發和管理基於Windows Service後臺任務執行器。且任務信息能夠被持久保存。內置提供集成化的控制檯。服務器

經過Nuget就能夠在你的應用程序中安裝Hangfire:Install-Package Hangfire併發

Hangfire的具備以下特性和有點:函數

  • 支持基於隊列的任務處理:任務執行不是同步的,而是放到一個持久化隊列中,以便立刻把請求控制權返回給調用者。使用方法:BackgroundJob.Enqueue(() => Console.WriteLine("Simple!"));
  • 延遲任務執行:不是立刻調用方法,而是設定一個將來時間點再來執行。使用方法:BackgroundJob.Schedule(() => Console.WriteLine("Reliable!"), TimeSpan.FromDays(7));
  • 循環任務執行:只須要簡單的一行代碼就能夠添加劇復執行的任務,其內置了常見的時間循環模式,也能夠基於CRON表達式來設定複雜的模式。使用方法:RecurringJob.AddOrUpdate(() => Console.WriteLine("Transparent!"), Cron.Daily);
  • 持久化保存任務、隊列、統計信息:默認使用SQL Server,也能夠配合消息隊列來下降隊列處理延遲,或配置使用Redis來得到更好的性能表現
  • 內置自動重試機制:能夠設定重試次數,還能夠手動在控制檯重啓任務
  • 除了調用靜態方法外還支持實例方法
  • 可以捕獲多語言狀態:便可以把調用者的Thread.CurrentCulture和Thread.CurrentUICulture信息同任務持久保存在一塊兒,以便任務執行的時候多語言信息是一致的
  • 支持任務取消:使用CancellationToken這樣的機制來處理任務取消邏輯
  • 支持IoC容器:目前支持Ninject和Autofac比較經常使用的開源IoC容器
  • 支持Web集羣:能夠在一臺或多臺機器上運行多個Hangfire實例以便實現冗餘備份
  • 支持多隊列:同一個Hangfire實例能夠支持多個隊列,以便更好的控制任務的執行方式
  • 併發級別的控制:默認是處理器數量的5倍工做行程,固然也能夠本身設定
  • 具有很好的擴展性:有不少擴展點來控制持久存儲方式、IoC容器支持等

爲何要使用Hangfire這樣的函數庫呢?我以爲好處有以下幾個方面:工具

  1. 開發簡單:無需本身額外作開發,就能夠實現任務的隊列執行、延遲執行和重複執行
  2. 部署簡單:能夠同主ASP.NET應用部署在一塊兒,測試和維護都相對簡單
  3. 遷移簡單:因爲宿主不只限於ASP.NET,那麼將來能夠很是容易的把任務執行器放到其餘地方(須要改變的就是在其餘宿主中啓動Hangfire服務器)
  4. 擴展簡單:因爲開源且有不少擴展點,在現有插件都不知足本身須要的狀況下可以容易的進行擴展

以前我把Hangfire運用到兩種狀況下:post

  1. 後臺長時間的科學計算:這樣就可讓請求立刻返回給客戶端,後臺完成長時間計算後,用SignalR實時提醒用戶
  2. 後臺羣發郵件:經過延遲和循環任務分批經過SendCloud這樣的服務發送羣發郵件

固然,Hangfire的應用場景還不少,好比在後臺處理電商賣家的訂單。性能

相關文章
相關標籤/搜索