成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

一篇文章帶你了解Hangfire

開發 后端
Hangfire 適用于大多數 .NET 平臺:.NET Framework 4.5 或更高版本、.NET Core 1.0 或更高版本,或任何與 .NET Standard 1.3 兼容的平臺。

 [[408195]]

本文轉載自微信公眾號「后端Q」,作者conan。轉載本文請聯系后端Q公眾號。

要求

Hangfire 適用于大多數 .NET 平臺:.NET Framework 4.5 或更高版本、.NET Core 1.0 或更高版本,或任何與 .NET Standard 1.3 兼容的平臺。您可以將它與幾乎任何應用程序框架集成,包括 ASP.NET、ASP.NET Core、控制臺應用程序、Windows 服務、WCF,以及社區驅動的框架,如 Nancy 或 ServiceStack。

存儲

存儲是 Hangfire 保存與后臺作業處理相關的所有信息的地方。類型、方法名稱、參數等所有細節都被序列化并放入存儲中,沒有數據保存在進程的內存中。存儲子系統在 Hangfire 中被很好地抽象出來,可以為 RDBMS 和 NoSQL 解決方案實現。

這是您必須做出的主要決定,也是開始使用框架之前所需的唯一配置。以下示例顯示如何使用 SQL Server 數據庫配置 Hangfire。請注意,連接字符串可能會有所不同,具體取決于您的環境。

  1. GlobalConfiguration.Configuration 
  2.     .UseSqlServerStorage(@"Server=.\SQLEXPRESS; Database=Hangfire.Sample; Integrated Security=True"); 

客戶端

Client 負責創建后臺作業并將它們保存到 Storage 中。后臺作業是一個應該在當前執行上下文之外執行的工作單元,例如在后臺線程、其他進程中,甚至在不同的服務器上——這一切都可以通過 Hangfire 實現,即使沒有額外的配置。

  1. BackgroundJob.Enqueue(() => Console.WriteLine("Hello, world!")); 

請注意,這不是委托,而是表達式樹。Hangfire 不是立即調用該方法,而是序列化類型 ( System.Console)、方法名稱 ( WriteLine,帶有所有參數類型以便稍后識別它) 和所有給定的參數,并將其放入 Storage。

服務器

Hangfire Server 通過查詢存儲來處理后臺作業。粗略地說,它是一組后臺線程,它們偵聽 Storage 以獲取新的后臺作業,并通過反序列化類型、方法和參數來執行它們。

您可以將此后臺作業服務器放置在您想要的任何進程中,包括像 ASP.NET 這樣的危險進程——即使您終止了一個進程,您的后臺作業也會在重新啟動后自動重試。因此,在 Web 應用程序的基本配置中,您不再需要使用 Windows 服務進行后臺處理。

  1. using (new BackgroundJobServer()) 
  2.     Console.ReadLine(); 

安裝

Hangfire 作為幾個 NuGet 包分發,從主要的 Hangfire.Core 開始,它包含所有主要類和抽象。其他包如 Hangfire.SqlServer 提供功能或抽象實現。要開始使用 Hangfire,請安裝主軟件包并選擇可用的存儲空間之一。

Visual Studio 2017 發布后,出現了一種全新的 NuGet 包安裝方式。所以我放棄了列出安裝 NuGet 包的所有方法,并回退到使用該dotnet應用程序幾乎在任何地方都可用的方法。

  1. dotnet add package Hangfire.Core 
  2. dotnet add package Hangfire.SqlServer 

配置

使用GlobalConfiguration類執行配置。它的Configuration屬性提供了很多擴展方法,既有來自 Hangfire.Core 的,也有來自其他包的。如果你安裝了一個新的包,不要猶豫,檢查是否有新的擴展方法。

  1. GlobalConfiguration.Configuration 
  2.     .SetDataCompatibilityLevel(CompatibilityLevel.Version_170) 
  3.     .UseSimpleAssemblyNameTypeSerializer() 
  4.     .UseRecommendedSerializerSettings() 
  5.     .UseSqlServerStorage("Database=Hangfire.Sample; Integrated Security=True;", new SqlServerStorageOptions 
  6.     { 
  7.         CommandBatchMaxTimeout = TimeSpan.FromMinutes(5), 
  8.         SlidingInvisibilityTimeout = TimeSpan.FromMinutes(5), 
  9.         QueuePollInterval = TimeSpan.Zero, 
  10.         UseRecommendedIsolationLevel = true
  11.         UsePageLocksOnDequeue = true
  12.         DisableGlobalLocks = true 
  13.     }) 
  14.     .UseBatches() 
  15.     .UsePerformanceCounters(); 
  16.      

方法調用可以鏈接起來,因此不需要一次又一次地使用類名。全局配置是為了簡單起見,幾乎每個 Hangfire 類都允許您指定存儲、過濾器等的覆蓋。在 ASP.NET Core 環境中,全局配置類隱藏在AddHangfire方法中。

用法

以下是所有運行中的 Hangfire 組件,作為打印“Hello, world!”的完整工作示例。來自后臺線程的消息。您可以注釋與服務器相關的行,并多次運行該程序——只要您再次取消注釋這些行,就會處理所有后臺作業。

  1. using System; 
  2. using Hangfire; 
  3. using Hangfire.SqlServer; 
  4.  
  5. namespace ConsoleApplication2 
  6.     class Program 
  7.     { 
  8.         static void Main() 
  9.         { 
  10.             GlobalConfiguration.Configuration 
  11.                 .SetDataCompatibilityLevel(CompatibilityLevel.Version_170) 
  12.                 .UseColouredConsoleLogProvider() 
  13.                 .UseSimpleAssemblyNameTypeSerializer() 
  14.                 .UseRecommendedSerializerSettings() 
  15.                 .UseSqlServerStorage("Database=Hangfire.Sample; Integrated Security=True;", new SqlServerStorageOptions 
  16.                 { 
  17.                     CommandBatchMaxTimeout = TimeSpan.FromMinutes(5), 
  18.                     SlidingInvisibilityTimeout = TimeSpan.FromMinutes(5), 
  19.                     QueuePollInterval = TimeSpan.Zero, 
  20.                     UseRecommendedIsolationLevel = true
  21.                     UsePageLocksOnDequeue = true
  22.                     DisableGlobalLocks = true 
  23.                 }); 
  24.  
  25.             BackgroundJob.Enqueue(() => Console.WriteLine("Hello, world!")); 
  26.  
  27.             using (var server = new BackgroundJobServer()) 
  28.             { 
  29.                 Console.ReadLine(); 
  30.             } 
  31.         } 
  32.     } 

 

 

責任編輯:武曉燕 來源: 后端Q
相關推薦

2023-05-12 08:19:12

Netty程序框架

2023-09-06 14:57:46

JavaScript編程語言

2020-12-08 08:09:49

SVG圖標Web

2021-05-18 08:30:42

JavaScript 前端JavaScript時

2021-06-24 09:05:08

JavaScript日期前端

2021-09-27 09:18:30

ListIterato接口方法

2021-01-26 23:46:32

JavaScript數據結構前端

2021-03-05 18:04:15

JavaScript循環代碼

2021-03-09 14:04:01

JavaScriptCookie數據

2024-04-19 14:23:52

SwitchJavaScript開發

2023-07-30 15:18:54

JavaScript屬性

2021-02-26 20:01:57

SVG濾鏡元素

2023-05-08 08:21:15

JavaNIO編程

2024-01-30 13:47:45

2020-11-10 10:48:10

JavaScript屬性對象

2021-06-04 09:56:01

JavaScript 前端switch

2021-01-29 18:41:16

JavaScript函數語法

2021-02-02 18:39:05

JavaScript

2020-10-20 15:37:48

了解JavaScrip

2020-10-22 09:08:34

JavaScript
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 视频在线一区二区 | 久久久久国产精品 | 精品伊人久久 | 三级成人在线 | 国产在线一区二区三区 | 中文字幕一区二区三区四区五区 | 亚洲网在线 | 伦理午夜电影免费观看 | 国产精品免费一区二区三区 | 欧美激情精品久久久久久变态 | 日韩视频在线观看中文字幕 | 美女一区 | 九九热视频这里只有精品 | 精品成人免费视频 | 午夜一区二区三区 | 国产成人短视频在线观看 | 天天综合网永久 | 国产精品欧美一区二区三区不卡 | 日韩精品a在线观看图片 | 久久久久久黄 | 亚洲欧美日韩电影 | 国产精品一区二区三区在线 | 日本一区二区三区在线观看 | 国产日韩欧美91 | 99精品亚洲国产精品久久不卡 | 天堂一区二区三区四区 | 在线免费看91 | 欧美中文字幕一区二区三区 | 99精品国产一区二区三区 | 国产精品毛片无码 | 99久久精品视频免费 | 黄色大片网站 | 日本一区高清 | 日韩欧美在线观看视频 | 国产精品综合网 | 黄视频国产 | 午夜电影福利 | 久久久国产一区二区三区 | 国产做a爱片久久毛片 | 日韩国产欧美在线观看 | 69亚洲精品|