Hangfire執(zhí)行后臺(tái)任務(wù)工具
Hangfire是一個(gè)開(kāi)源且商業(yè)免費(fèi)使用的工具函數(shù)庫(kù)。可以讓你非常容易地在ASP.NET應(yīng)用(也可以不在ASP.NET應(yīng)用)中執(zhí)行多種類(lèi)型的后臺(tái)任務(wù),而無(wú)需自行定制開(kāi)發(fā)和管理基于Windows Service后臺(tái)任務(wù)執(zhí)行器。且任務(wù)信息可以被持久保存。內(nèi)置提供集成化的控制臺(tái)。
通過(guò)Nuget就可以在你的應(yīng)用程序中安裝Hangfire:Install-Package Hangfire
Hangfire的具有如下特性和特點(diǎn):
-
支持基于隊(duì)列的任務(wù)處理:任務(wù)執(zhí)行不是同步的,而是放到一個(gè)持久化隊(duì)列中,以便馬上把請(qǐng)求控制權(quán)返回給調(diào)用者。使用方法:BackgroundJob.Enqueue(() => Console.WriteLine("Simple!"));
-
延遲任務(wù)執(zhí)行:不是馬上調(diào)用方法,而是設(shè)定一個(gè)未來(lái)時(shí)間點(diǎn)再來(lái)執(zhí)行。使用方法:BackgroundJob.Schedule(() => Console.WriteLine("Reliable!"), TimeSpan.FromDays(7));
-
循環(huán)任務(wù)執(zhí)行:只需要簡(jiǎn)單的一行代碼就可以添加重復(fù)執(zhí)行的任務(wù),其內(nèi)置了常見(jiàn)的時(shí)間循環(huán)模式,也可以基于CRON表達(dá)式來(lái)設(shè)定復(fù)雜的模式。使用方法:RecurringJob.AddOrUpdate(() => Console.WriteLine("Transparent!"), Cron.Daily);
-
持久化保存任務(wù)、隊(duì)列、統(tǒng)計(jì)信息:默認(rèn)使用SQL Server,也可以配合消息隊(duì)列來(lái)降低隊(duì)列處理延遲,或配置使用Redis來(lái)獲得更好的性能表現(xiàn)
-
內(nèi)置自動(dòng)重試機(jī)制:可以設(shè)定重試次數(shù),還可以手動(dòng)在控制臺(tái)重啟任務(wù)
-
除了調(diào)用靜態(tài)方法外還支持實(shí)例方法
-
能夠捕獲多語(yǔ)言狀態(tài):即可以把調(diào)用者的Thread.CurrentCulture和Thread.CurrentUICulture信息同任務(wù)持久保存在一起,以便任務(wù)執(zhí)行的時(shí)候多語(yǔ)言信息是一致的
-
支持任務(wù)取消:使用CancellationToken這樣的機(jī)制來(lái)處理任務(wù)取消邏輯
-
支持IoC容器:目前支持Ninject和Autofac比較常用的開(kāi)源IoC容器
-
支持Web集群:可以在一臺(tái)或多臺(tái)機(jī)器上運(yùn)行多個(gè)Hangfire實(shí)例以便實(shí)現(xiàn)冗余備份
-
支持多隊(duì)列:同一個(gè)Hangfire實(shí)例可以支持多個(gè)隊(duì)列,以便更好的控制任務(wù)的執(zhí)行方式
-
并發(fā)級(jí)別的控制:默認(rèn)是處理器數(shù)量的5倍工作行程,當(dāng)然也可以自己設(shè)定
-
具備很好的擴(kuò)展性:有很多擴(kuò)展點(diǎn)來(lái)控制持久存儲(chǔ)方式、IoC容器支持等
為什么要使用Hangfire這樣的函數(shù)庫(kù)呢?我覺(jué)得好處有如下幾個(gè)方面:
-
開(kāi)發(fā)簡(jiǎn)單:無(wú)需自己額外做開(kāi)發(fā),就可以實(shí)現(xiàn)任務(wù)的隊(duì)列執(zhí)行、延遲執(zhí)行和重復(fù)執(zhí)行
-
部署簡(jiǎn)單:可以同主ASP.NET應(yīng)用部署在一起,測(cè)試和維護(hù)都相對(duì)簡(jiǎn)單
-
遷移簡(jiǎn)單:由于宿主不僅限于ASP.NET,那么未來(lái)可以非常容易的把任務(wù)執(zhí)行器放到其他地方(需要改變的就是在其他宿主中啟動(dòng)Hangfire服務(wù)器)
-
擴(kuò)展簡(jiǎn)單:由于開(kāi)源且有很多擴(kuò)展點(diǎn),在現(xiàn)有插件都不滿(mǎn)足自己需要的情況下能夠容易的進(jìn)行擴(kuò)展
之前我把Hangfire運(yùn)用到兩種情況下:
-
后臺(tái)長(zhǎng)時(shí)間的科學(xué)計(jì)算:這樣就可以讓請(qǐng)求馬上返回給客戶(hù)端,后臺(tái)完成長(zhǎng)時(shí)間計(jì)算后,用SignalR實(shí)時(shí)提醒用戶(hù)
-
后臺(tái)群發(fā)郵件:通過(guò)延遲和循環(huán)任務(wù)分批通過(guò)SendCloud這樣的服務(wù)發(fā)送群發(fā)郵件
當(dāng)然,Hangfire的應(yīng)用場(chǎng)景還很多,比如在后臺(tái)處理電商賣(mài)家的訂單。
