Hangfire allows you to kick off method calls outside of the request processing pipeline in a very easy, but reliable way. These method invocations are performed in a background thread and called background jobs.
From the 10.000-feet view the library consists of three main components: client, storage and server. Here is a small diagram that describes the main processes in Hangfire:
Hangfire is not tied to the specific .NET application type. You can use it in ASP.NET :doc:`web applications <background-processing/processing-jobs-in-web-app>`, non-ASP.NET web applications, in :doc:`console applications <background-processing/processing-jobs-in-console-app>` or :doc:`Windows services <background-processing/processing-jobs-in-windows-service>`. Here are the requirements:
- .NET Framework 4.5.1 or later
- Persistent storage (listed below)
- Newtonsoft.Json library ≥ 5.0.1
You can create any kind of background jobs using Hangfire: :doc:`fire-and-forget <../background-methods/calling-methods-in-background>` (to offload the method invocation), :doc:`delayed <../background-methods/calling-methods-with-delay>` (to perform the call after some time) and :doc:`recurring <../background-methods/performing-recurrent-tasks>` (to perform methods hourly, daily and so on).
Hangfire does not require you to create special classes. Background jobs are based on regular static or instance methods invocation.
var client = new BackgroundJobClient();
client.Enqueue(() => Console.WriteLine("Easy!"));
client.Delay(() => Console.WriteLine("Reliable!"), TimeSpan.FromDays(1));
There is also more easy way to create background jobs – the BackgroundJob
class that allows you to use static methods to perform the creation task.
BackgroundJob.Enqueue(() => Console.WriteLine("Hello!"));
The control is returned to a caller just after Hangfire serializes the given information and saves it to the storage.
Hangfire keeps background jobs and other information that relates to the processing inside a persistent storage. Persistence helps background jobs to survive on application restarts, server reboots, etc. This is the main distinction between performing background jobs using CLR's Thread Pool and Hangfire. Different storage backends are supported:
- :doc:`SQL Azure, SQL Server 2008 R2 <../configuration/using-sql-server>` (and later of any edition, including Express)
- :doc:`Redis <../configuration/using-redis>`
GlobalConfiguration.Configuration.UseSqlServerStorage("db_connection");
Background jobs are processed by :doc:`Hangfire Server <../background-processing/processing-background-jobs>`. It is implemented as a set of dedicated (not thread pool's) background threads that fetch jobs from a storage and process them. Server is also responsible to keep the storage clean and remove old data automatically.
All you need is to create an instance of the BackgroundJobServer
class and start the processing:
using (new BackgroundJobServer())
{
Console.WriteLine("Hangfire Server started. Press ENTER to exit...");
Console.ReadLine();
}
Hangfire uses reliable fetching algorithm for each storage backend, so you can start the processing inside a web application without a risk of losing background jobs on application restarts, process termination and so on.
.. toctree:: :maxdepth: 2 :titlesonly: :includehidden: getting-started/index configuration/index background-methods/index background-processing/index best-practices deployment-to-production/index extensibility/index tutorials/index upgrade-guides/index