Hangfire 1.8.2

The ID prefix of this package has been reserved for one of the owners of this package by NuGet.org. Prefix Reserved
dotnet add package Hangfire --version 1.8.2
NuGet\Install-Package Hangfire -Version 1.8.2
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Hangfire" Version="1.8.2" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Hangfire --version 1.8.2
#r "nuget: Hangfire, 1.8.2"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Hangfire as a Cake Addin
#addin nuget:?package=Hangfire&version=1.8.2

// Install Hangfire as a Cake Tool
#tool nuget:?package=Hangfire&version=1.8.2

An easy and reliable way to perform fire-and-forget, delayed and recurring, long-running, short-running, CPU or I/O intensive tasks inside ASP.NET applications. No Windows Service / Task Scheduler required. Even ASP.NET is not required.
Backed by Redis, SQL Server, SQL Azure or MSMQ. This is a .NET alternative to Sidekiq, Resque and Celery.
https://www.hangfire.io/

There are no supported framework assets in this package.

Learn more about Target Frameworks and .NET Standard.

NuGet packages (173)

Showing the top 5 NuGet packages that depend on Hangfire:

Package Downloads
N3O.Umbraco.Scheduler

TODO

ImmediaC.SimpleCms

.Net Core CMS

VirtoCommerce.Platform.Hangfire

Virto Commerce is a flexible B2B ecommerce solution that offers powerful tools for enterprise business users. https://virtocommerce.com

ComplianceAuditSystems.AcabimCommonServices

Package Description

Bnsights.Mvc

Bnsights.Mvc is RAD Helper DLL for MVC Projects in Bnsights DMCC. Also known as Bnsights Business Solutions Framework (BBSF).

GitHub repositories (19)

Showing the top 5 popular GitHub repositories that depend on Hangfire:

Repository Stars
Ombi-app/Ombi
Want a Movie or TV Show on Plex/Emby/Jellyfin? Use Ombi!
blazorhero/CleanArchitecture
Clean Architecture Template for Blazor WebAssembly Built with MudBlazor Components.
fullstackhero/dotnet-webapi-boilerplate
Clean Architecture Template for .NET 7.0 WebApi built with Multitenancy Support.
Kareadita/Kavita
Kavita is a fast, feature rich, cross platform reading server. Built with a focus for manga and the goal of being a full solution for all your reading needs. Setup your own server and share your reading collection with your friends and family.
dotnetcore/osharp
OSharp是一个基于.NetCore的快速开发框架,框架对 AspNetCore 的配置、依赖注入、日志、缓存、实体框架、Mvc(WebApi)、身份认证、功能权限、数据权限等模块进行更高一级的自动化封装,并规范了一套业务实现的代码结构与操作流程,使 .Net Core 框架更易于应用到实际项目开发中。
Version Downloads Last updated
1.8.2 653 5/26/2023
1.8.1 10,429 5/18/2023
1.8.0 47,908 4/28/2023
1.8.0-rc4 530 4/25/2023
1.8.0-rc3 3,870 3/30/2023
1.8.0-rc2 27,726 11/23/2022
1.8.0-rc1 45,398 6/13/2022
1.8.0-beta4 84,371 11/12/2021
1.8.0-beta3 93,699 7/5/2021
1.8.0-beta2 10,466 4/15/2021
1.8.0-beta1 3,417 3/19/2021
1.7.35 1,043 5/18/2023
1.7.34 110,776 3/30/2023
1.7.33 363,495 1/31/2023
1.7.32 541,146 11/21/2022
1.7.31 1,056,575 8/19/2022
1.7.30 870,258 6/10/2022
1.7.29 224,637 5/23/2022
1.7.28 2,278,697 12/18/2021
1.7.27 750,114 11/3/2021
1.7.26 116,598 10/27/2021
1.7.25 903,946 8/30/2021
1.7.24 922,501 6/28/2021
1.7.23 516,251 5/28/2021
1.7.22 724,234 4/13/2021
1.7.21 11,239 4/12/2021
1.7.20 306,241 3/19/2021
1.7.19 1,091,552 1/15/2021
1.7.18 942,390 11/20/2020
1.7.17 470,261 10/20/2020
1.7.16 100,589 10/14/2020
1.7.15 66,686 10/8/2020
1.7.14 407,492 9/24/2020
1.7.13 126,896 9/15/2020
1.7.12 699,378 7/24/2020
1.7.11 1,974,212 4/15/2020
1.7.10 257,427 4/2/2020
1.7.9 1,832,821 1/20/2020
1.7.8 656,380 12/5/2019
1.7.7 718,979 10/22/2019
1.7.6 1,378,081 8/5/2019
1.7.5 290,997 7/18/2019
1.7.4 295,295 6/28/2019
1.7.3 574,633 5/23/2019
1.7.2 395,331 4/29/2019
1.7.1 353,160 4/16/2019
1.7.0 313,724 3/29/2019
1.6.30 18,853 4/29/2021
1.6.29 43,918 4/15/2020
1.6.28 69,580 1/14/2020
1.6.27 58,397 6/27/2019
1.6.26 73,199 5/23/2019
1.6.25 18,503 4/9/2019
1.6.24 92,372 3/27/2019
1.6.23 192,033 3/13/2019
1.6.22 608,038 1/25/2019
1.6.21 1,028,327 11/1/2018
1.6.20 1,004,735 7/31/2018
1.6.19 1,171,299 4/6/2018
1.6.18 25,263 4/5/2018
1.6.17 1,418,179 9/19/2017
1.6.16 143,140 9/2/2017
1.6.15 220,830 8/8/2017
1.6.14 258,929 6/16/2017
1.6.13 54,694 6/7/2017
1.6.12 505,834 3/22/2017
1.6.11 34,862 3/14/2017
1.6.10 9,564 3/13/2017
1.6.9 44,243 3/2/2017
1.6.8 316,649 12/21/2016
1.6.7 175,620 11/25/2016
1.6.6 158,588 10/13/2016
1.6.5 94,814 9/24/2016
1.6.4 74,140 8/30/2016
1.6.3 37,632 8/19/2016
1.6.2 44,245 8/5/2016
1.6.1 48,995 7/27/2016
1.6.0 29,445 7/15/2016
1.5.9 117,176 7/11/2016
1.5.8 38,055 6/17/2016
1.5.7 20,310 5/30/2016
1.5.6 57,410 4/22/2016
1.5.5 19,219 4/14/2016
1.5.4 43,069 3/22/2016
1.5.3 285,464 11/6/2015
1.5.2 21,870 10/15/2015
1.5.1 5,122 10/14/2015
1.5.0 50,513 10/1/2015
1.4.7 4,590 10/1/2015
1.4.6 24,137 8/29/2015
1.4.5 30,377 7/24/2015
1.4.4 4,120 7/23/2015
1.4.3 58,537 5/27/2015
1.4.2 12,087 5/6/2015
1.4.1 29,822 4/14/2015
1.3.4 56,049 2/4/2015
1.3.3 6,042 1/28/2015
1.3.2 4,141 1/27/2015
1.3.1 9,564 1/13/2015
1.3.0 9,900 12/10/2014
1.2.2 11,599 11/24/2014
1.2.1 3,841 11/22/2014
1.2.0 6,631 11/17/2014
1.1.1 23,653 9/5/2014
1.1.0 4,726 9/3/2014
1.0.2 7,541 7/1/2014
1.0.1 3,649 6/30/2014
1.0.0 3,955 6/30/2014
0.9.1 3,432 6/12/2014
0.9.0 2,249 6/7/2014
0.8.3 2,227 5/23/2014
0.8.2 2,094 5/21/2014
0.8.1 2,118 5/17/2014
0.8.0 3,282 5/2/2014
0.7.5 2,612 4/10/2014
0.7.4 2,230 4/7/2014
0.7.3 2,144 4/4/2014
0.7.2 2,107 4/4/2014
0.7.1 2,148 4/1/2014
0.7.0 2,184 3/22/2014
0.6.2 2,141 1/28/2014
0.6.1 2,057 1/27/2014
0.6.0 2,142 1/27/2014
0.5.2 2,145 11/19/2013
0.5.1 2,158 11/12/2013
0.5.0 3,505 11/10/2013

Release notes are available in our blog https://www.hangfire.io/blog/
Please see https://docs.hangfire.io/en/latest/upgrade-guides/upgrading-to-hangfire-1.8.html to learn how to upgrade.

1.8.2

Hangfire.Core

• Changed – Disable transactional job creation feature appeared in 1.8.0.
• Fixed – "Can not start continuation XXX" error when storage supports transactional job creation.

Hangfire.SqlServer

• Fixed – `InvalidOperationException` with new dashboard metrics when a database has multiple data/log files.

1.8.1
     
Hangfire.Core

• Added – `MisfireHandlingMode.Ignorable` to avoid scheduling recurring jobs on missed schedules.
• Added – Support disabling dark mode via the `DashboardOptions.DarkModeEnabled` property.
• Changed – Remove the 1-hour limitation for the `WithJobExpirationTimeout` configuration method.
• Fixed – Add missing `UseDefaultCulture` configuration method overloads.
• Fixed – Add missing `UseDashboardStylesheet` and `UseJobDetailsRenderer` configuration methods.
• Fixed – Give even more space for identifiers on the Recurring Jobs page.
• Fixed – `state-card-state-active` color is not very dark (by @coolhome).
• Fixed – Slightly change chart proportions to fit 4K in Dashboard UI.

Hangfire.SqlServer

• Fixed – Blocked workers regression since 1.7.33 when using multiple servers inside a process.
• Fixed – Target schema version is less than the current schema version error.
• Fixed – Implement database metrics without the need for additional permissions.
• Fixed – Use the `forceseek` table hint whenever possible to avoid performance drops.
     
Hangfire.NetCore

• Fixed – Add `net461` target for Hangfire.NetCore package to avoid missing method exceptions.

1.8.0

Hangfire.Core

• Breaking – Dropped the `NET45` platform target in favor of the `NET451` target to support Visual Studio 2022.

• Added – Introduce the `Job.Queue` property, so jobs now can have their own queue specified.
• Added – Method overloads to create background jobs directly with a custom default queue.
• Added – Method overloads to create recurring jobs directly with a custom default queue.
• Added – `IBackgroundJobClient.Create` method overloads with the new `queue` parameter.
• Added – Allow to filter exception types in `AutomaticRetryAttribute` by using the new `OnlyOn` property.
• Added – `DeletedState` now has the persisted `Exception` property populated after a failure.
• Added – `JobContinuationOptions.OnlyOnDeletedState` to create continuations after a failure.
• Added – `Exception` job parameter is passed to continuation when `UseResultsInContinuations` method is used.
• Added – `FromExceptionAttribute` to deal with an antecedent exception in a background job continuation.
• Added – Make it possible to specify multiple `JobContinuationOptions` values for a continuation.
• Added – `BackgroundJobServerOptions.IsLightweightServer` option to run a server with no storage processes.
• Added – Ability to use custom formattable resource identifiers for the `DisableConcurrentExecution` filter.
• Added – Pass `ServerId` to `FailedState` instances to simplify the debugging on different servers.
• Added – Allow to pass job parameters when creating a job (by @brian-knoll-micronetonline).
• Added – `MisfireHandlingMode.Strict` to create a job for each missed recurring job occurrence.
• Added – Support for default culture and UI culture via the `UseDefaultCulture` configuration method.
• Added – Introduce the `captureDefault` parameter in the `CaptureCulture` filter.
• Added – `IGlobalConfiguration.UseFilterProvider` extension method to unify the configuration.
• Added – Built-in `Remove` method for `JobFilterCollection` to remove global filters based on their type.
• Added – `CompatibilityLevel.Version_180` flag to avoid storing culture parameters when they are the same as the default ones.
• Changed – Create job atomically when `Transaction.CreateJob` feature is supported by the storage.
• Changed – Query time from storage in recurring and delayed schedulers when supported by storage.
• Changed – Move job to the `DeletedState` instead of `SucceededState` when its invocation was canceled by a filter.
• Changed – Speedup delayed jobs when a custom default queue is specified by avoiding extra state transition.
• Changed – Use UI culture from `CurrentCulture` parameter when `CurrentUICulture` one is missing.
• Changed – Increase the default value for the `BackgroundJobServerOptions.StopTimeout` to 500 ms.
• Deprecated – `AddOrUpdate` overloads with optional params defined in the `RecurringJobManagerExtensions` class.
• Deprecated – `AddOrUpdate` overloads with optional parameters defined in the `RecurringJob` class.
• Deprecated – `AddOrUpdate` method overloads with no `recurringJobId` parameter.
• Deprecated – `RecurringJobOptions.QueueName` property, new methods should be used instead.
• Breaking – Dropped `NET45` platform target in favor of `NET451` target to support Visual Studio 2022.

Dashboard UI
• Added – Dark mode support for Dashboard UI depending on the system settings (by @danillewin).
• Added – Dashboard UI now has a full-width layout to display more data (by @danillewin).
• Added – Allow to add custom JavaScript and CSS files to the Dashboard UI via the `DashboardRoutes` class.
• Added – `DefaultRecordsPerPage` property on the `DashboardOptions` class (by @PaulARoy).
• Added – `IGlobalConfiguration.UseJobDetailsRenderer` method for custom renderers for the Job Details page.
• Added – Display deleted jobs in the Realtime and History graphs when supported by storage.
• Added – `IGlobalConfiguration.UseDashboardMetrics` extension method to pass multiple metrics at once.
• Added – State renderer for the `DeletedState` to display its new exception property.
• Added – Support for new `MonitoringApi` methods for the Awaiting Jobs page.
• Changed – Make it possible to display methods of non-loaded jobs in the Dashboard UI when supported by storage.
• Changed – Improved display of realtime chart with more accents on failed and deleted jobs.
• Changed – Don't display the queue name in the state transition list when it's the `default` one.
• Changed – Display scheduled job count when the enqueued count is zero on the main metric.

Extensibility
• Added – `Factory`, `StateMachine`, and `Performer` properties to context classes to avoid injecting services.
• Added – Allow to pass custom data to `ApplyStateContext` and `ElectStateContext` instances.
• Added – Preserve custom data dictionary between the entire filter chain.
• Added – Allow to pass a transaction to background job state changer when new methods are implemented.
• Changed – Ignore some members when serializing a `JobFilterAttribute` instance to decrease the payload size.

Storage
• Added – Virtual `JobStorage.GetReadOnlyConnection` method intended to return `JobStorageConnection` for replicas.
• Added – Virtual `JobStorage.HasFeature` method for querying optional features.
• Added – The `JobStorageFeatures` class to avoid using magic strings in storage features.
• Added – Optional `GetSetCount`, `GetSetContains`, and `GetUtcDateTime` methods for the `JobStorageConnection` class.
• Added – Optional `AcquireDistributedLock` and `RemoveFromQueue` methods for the `JobStorageTransaction` class.
• Added – Optional `CreateJob` and `SetJobParameter` methods for the `JobStorageTransaction` class.
• Added – Optional `ParametersSnapshot` property for `BackgroundJob` and `JobData` classes to minimize roundtrips in the future.
• Added – Support for transactional acknowledgment using a new storage method for better handling some data loss scenarios.
• Added – Fetch `Retries` and `Awaiting` metrics in `StatisticsDto` properties when supported by storage.
• Added – The `JobStorageMonitor` class with more available methods for the new features.
• Changed – Allow to query job parameters without additional roundtrip when supported by storage.
• Changed – Expose state data dictionaries in list DTOs when supported by storage.
• Changed – Rely on storage indexing with the `Monitoring.AwaitingJobs` feature.

Internals
• Added – `IBackgroundProcess.UseBackgroundPool` now allows to pass thread configuration logic.
• Added – `BackgroundJobServerOptions.WorkerThreadConfigurationAction` option for custom thread configuration.
• Changed – Allow changing queues on the fly with custom worker configuration.
• Changed – Avoid storage roundtrip to query job data in worker, take data from previous state change.
• Changed – `FromParameterAttribute`-based logic now always overwrites arguments, even with non-null values.
• Changed – Turn the `JobContinuationOptions` enum into flags while still possible.
• Changed – Re-implement `TaskExtensions.WaitOneAsync` only with the `RegisterWaitForSingleObject` method.
• Changed – `ServerHeartbeatProcess` now uses `ThreadPriority.AboveNormal` to prioritize heartbeats.

Hangfire.NetCore

• Added – `IApplicationBuilder.UseHangfireServer` that accepts custom factory for `IBackgroundProcessingServer`.
• Added – `net451` and `netstandard1.3` targets for the package.
• Changed – Use `netstandard2.1` target instead of `netcoreapp3.0` for the package.
• Changed – Send the "stop" signal earlier when the host supports .NET Standard 2.1.
• Changed – Don't throw `ObjectDisposedException` when hosted service is disposed twice.

Hangfire.AspNetCore

• Breaking – Make the package to be dependent on Hangfire.NetCore and use the same types.
• Added – `IApplicationBuilder.UseHangfireServer` that accepts custom factory for `IBackgroundProcessingServer`.

Hangfire.SqlServer

• Breaking – Prioritise Microsoft.Data.SqlClient package over System.Data.SqlClient one.
• Breaking – Dropped the `NET45` platform target in favor of the `NET451` target to support Visual Studio 2022.

• Added – `Schema 8` migration with fixed `JobQueue.Id` column to use the `bigint` type.
• Added – `Schema 9` migration that creates an index for the `State.CreatedAt` column.
• Added – Automatic client package detection based on available types, preferring `System.Data.SqlClient` (by @0xced).
• Added – `SqlServerStorageOptions.DbProviderFactory` option to use a custom provider factory.
• Added – Clean up of old state entries of a non-finished job when `InactiveStateExpirationTimeout` is set.
• Added – `TryAutoDetectSchemaDependentOptions` option to automatically enable options based on the schema.
• Added – Optional experimental transactional acknowledge for SQL Server (`UseTransactionalAcknowledge` option).
• Added – Implement the `Connection.GetUtcDateTime` feature to make work the new changes in schedulers.
• Added – `SqlServerStorage.SchemaVersion` metric for Dashboard UI.
• Added – `DefaultQueueProvider` option to specify a custom default queue provider.
• Changed – Remove dependency on System.Data.SqlClient for Hangfire.SqlServer (by @0xced).
• Changed – Set default value for the `QueuePollInterval` option to `TimeSpan.Zero`.
• Changed – Polling delay when `QueuePollInterval` is set to zero now defaults to 200 ms.
• Changed – Sliding invisibility timeout-based fetching method is now used by default with a 5-minute timeout.
• Changed – Use command batching by default with a 5-minute maximum timeout.
• Changed – Enable the `UseRecommendedIsolationLevel` option by default.
• Changed – `GetJobData` now populates the `JobData.ParametersSnapshot` property to avoid additional roundtrips.
• Changed – Display scheduled and processing jobs in ascending order in Dashboard UI.
• Changed – Implement the `Transaction.AcquireDistributedLock` feature.
• Changed – Implement the `GetSetCount.Limited feature`.
• Changed – Implement the `GetSetContains feature`.
• Changed – Bump the internal version of Dapper to 2.0.123.
• Changed – Enable common metrics for SQL Server storage to be shown by default.
• Changed – Enable the `Monitoring.AwaitingJobs` feature for SQL storage.
• Deprecated – `UsePageLocksOnDequeue` option is now obsolete and doesn't affect anything.

Hangfire.SqlServer.Msmq

• Breaking – Dropped the `NET45` platform target in favor of the `NET451` target to support Visual Studio 2022.