Hangfire.Core 1.8.4

Prefix Reserved
There is a newer version of this package available.
See the version list below for details.
dotnet add package Hangfire.Core --version 1.8.4                
NuGet\Install-Package Hangfire.Core -Version 1.8.4                
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.Core" Version="1.8.4" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Hangfire.Core --version 1.8.4                
#r "nuget: Hangfire.Core, 1.8.4"                
#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.Core as a Cake Addin
#addin nuget:?package=Hangfire.Core&version=1.8.4

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

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/

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
.NET Core netcoreapp1.0 was computed.  netcoreapp1.1 was computed.  netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard1.3 is compatible.  netstandard1.4 was computed.  netstandard1.5 was computed.  netstandard1.6 was computed.  netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net451 is compatible.  net452 was computed.  net46 is compatible.  net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen30 was computed.  tizen40 was computed.  tizen60 was computed. 
Universal Windows Platform uap was computed.  uap10.0 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (446)

Showing the top 5 NuGet packages that depend on Hangfire.Core:

Package Downloads
Hangfire.SqlServer

SQL Server 2008+ (including Express), SQL Server LocalDB and SQL Azure storage support for Hangfire, a background job framework for .NET applications.

Hangfire

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/

Hangfire.NetCore

.NET Core's Worker Service host support for Hangfire, a background job framework for .NET applications.

Hangfire.PostgreSql

PostgreSql storage implementation for Hangfire (background job system for ASP.NET and aspnet core applications).

Hangfire.MemoryStorage

A memory storage for Hangfire

GitHub repositories (45)

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

Repository Stars
aspnetboilerplate/aspnetboilerplate
ASP.NET Boilerplate - Web Application Framework
MassTransit/MassTransit
Distributed Application Framework for .NET
Xabaril/AspNetCore.Diagnostics.HealthChecks
Enterprise HealthChecks for ASP.NET Core Diagnostics Package
fullstackhero/blazor-starter-kit
Clean Architecture Template for Blazor WebAssembly Built with MudBlazor Components.
eventflow/EventFlow
Async/await first CQRS+ES and DDD framework for .NET
Version Downloads Last updated
1.8.15 194,603 10/23/2024
1.8.14 4,105,409 6/11/2024
1.8.12 3,305,084 4/3/2024
1.8.11 1,901,700 2/23/2024
1.8.10 902,666 2/12/2024
1.8.9 1,122,404 1/24/2024
1.8.7 1,259,836 12/29/2023
1.8.6 3,939,354 10/18/2023
1.8.5 3,439,287 8/11/2023
1.8.4 947,666 7/27/2023
1.8.3 1,546,226 6/27/2023
1.8.2 2,437,687 5/26/2023
1.8.1 500,097 5/18/2023
1.8.0 5,670,598 4/28/2023
1.7.37 121,487 4/8/2024
1.7.36 449,682 6/29/2023
1.7.35 1,909,747 5/18/2023
1.7.34 2,084,229 3/30/2023
1.7.33 3,613,527 1/31/2023
1.7.32 3,773,176 11/21/2022
1.7.31 6,751,122 8/19/2022
1.7.30 4,101,741 6/10/2022
1.7.29 1,504,317 5/23/2022
1.7.28 12,261,371 12/18/2021
1.7.27 5,389,714 11/3/2021
1.7.26 481,912 10/27/2021
1.7.25 3,611,360 8/30/2021 1.7.25 has at least one vulnerability with high severity.
1.7.24 3,487,403 6/28/2021
1.7.23 1,661,079 5/28/2021
1.7.22 2,674,844 4/13/2021
1.7.21 54,709 4/12/2021
1.7.20 1,236,234 3/19/2021
1.7.19 5,060,511 1/15/2021
1.7.18 4,947,009 11/20/2020
1.7.17 2,552,941 10/20/2020
1.7.16 433,288 10/14/2020
1.7.15 335,799 10/8/2020
1.7.14 899,331 9/24/2020
1.7.13 525,934 9/15/2020
1.7.12 2,227,752 7/24/2020
1.7.11 7,827,934 4/15/2020
1.7.10 1,218,179 4/2/2020
1.7.9 11,786,605 1/20/2020
1.7.8 2,202,391 12/5/2019
1.7.7 2,156,422 10/22/2019
1.7.6 4,911,016 8/5/2019
1.7.5 587,009 7/18/2019
1.7.4 692,013 6/28/2019
1.7.3 2,128,641 5/23/2019
1.7.2 2,416,789 4/29/2019
1.7.1 761,510 4/16/2019
1.7.0 4,134,566 3/29/2019
1.6.30 53,794 4/29/2021
1.6.29 100,493 4/15/2020
1.6.28 100,537 1/14/2020
1.6.27 82,867 6/27/2019
1.6.26 112,850 5/23/2019
1.6.25 51,674 4/9/2019
1.6.24 179,856 3/27/2019
1.6.23 334,327 3/13/2019
1.6.22 1,363,574 1/25/2019
1.6.21 4,964,318 11/1/2018
1.6.20 3,338,725 7/31/2018
1.6.19 1,950,957 4/6/2018
1.6.18 50,251 4/5/2018
1.6.17 3,541,655 9/19/2017
1.6.16 604,261 9/2/2017
1.6.15 478,553 8/8/2017
1.6.14 840,182 6/16/2017
1.6.13 133,303 6/7/2017
1.6.12 1,489,587 3/22/2017
1.6.11 58,836 3/14/2017
1.6.10 58,868 3/13/2017
1.6.9 105,133 3/2/2017
1.6.8 538,809 12/21/2016
1.6.7 304,602 11/25/2016
1.6.6 424,736 10/13/2016
1.6.5 190,753 9/24/2016
1.6.4 131,344 8/30/2016
1.6.3 202,428 8/19/2016
1.6.2 94,982 8/5/2016
1.6.1 2,526,352 7/27/2016
1.6.0 13,511,145 7/15/2016
1.5.9 343,866 7/11/2016
1.5.8 76,594 6/17/2016
1.5.7 47,805 5/30/2016
1.5.6 138,447 4/22/2016
1.5.5 33,495 4/14/2016
1.5.4 76,540 3/22/2016
1.5.3 553,418 11/6/2015
1.5.2 88,768 10/15/2015
1.5.1 10,832 10/14/2015
1.5.0 747,108 10/1/2015
1.4.7 10,944 10/1/2015
1.4.6 65,058 8/29/2015
1.4.5 63,852 7/24/2015
1.4.4 9,606 7/23/2015
1.4.3 104,183 5/27/2015
1.4.2 29,980 5/6/2015
1.4.1 56,781 4/14/2015
1.3.4 95,554 2/4/2015
1.3.3 13,696 1/28/2015
1.3.2 10,168 1/27/2015
1.3.1 16,227 1/13/2015
1.3.0 17,984 12/10/2014
1.2.2 18,919 11/24/2014
1.2.1 9,292 11/22/2014
1.2.0 12,308 11/17/2014
1.1.1 229,340 9/5/2014
1.1.0 11,922 9/3/2014
1.0.2 14,252 7/1/2014
1.0.1 40,750 6/30/2014
1.0.0 11,014 6/30/2014
0.9.1 11,519 6/12/2014
0.9.0 9,400 6/7/2014
0.8.3 10,307 5/23/2014
0.8.2 9,465 5/21/2014
0.8.1 11,248 5/17/2014
0.8.0 10,596 5/2/2014
0.7.5 10,567 4/10/2014
0.7.4 8,956 4/7/2014
0.7.3 8,732 4/4/2014
0.7.1 9,302 4/1/2014
0.7.0 16,525 3/22/2014
0.6.2 5,389 1/28/2014
0.6.1 5,282 1/27/2014
0.5.2 5,326 11/19/2013
0.5.1 5,345 11/12/2013
0.5.0 6,003 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.4
• Added – Pass server id from a worker to the `PerformContext.ServerId` property available in filters.
• Fixed – Send heartbeats until full background processing server shutdown.

1.8.3
• Changed – Allow to configure `MaxLinesInStackTrace` for a particular `FailedState` instance.
• Fixed – Remove job id from schedule when it's not in the Scheduled state for some reason.
• Fixed – Missing invocations of recurring jobs when the new "Ignorable" option is used.
• Fixed – Make `DisableConcurrentExecutionAttribute` and `LatencyTimeoutAttribute` serializable.

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

1.8.1
• 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.

1.8.0
• 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.