Hangfire 任務調度


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

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容器支持等
     






免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM