Hangfire.Core 1.7.12

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.7.12                
NuGet\Install-Package Hangfire.Core -Version 1.7.12                
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.7.12" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Hangfire.Core --version 1.7.12                
#r "nuget: Hangfire.Core, 1.7.12"                
#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.7.12

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

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 net45 is compatible.  net451 was computed.  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

https://www.hangfire.io/blog/

Please see https://docs.hangfire.io/en/latest/upgrade-guides/upgrading-to-hangfire-1.7.html to learn how to upgrade from 1.6.X.

1.7.12
• Added – Display actual job payload and exception message on job details page when could find the method.
• Added – French translation for Dashboard UI (by @PaulARoy).
• Added – Expose IStorageConnection.GetRecurringJobs(IEnumerable ids) to public.
• Changed – Bump thread priority in heartbeat process for constrained environments.
• Changed – Display job properties in a dedicated row in job details page.
• Fixed – Avoid storage round-trip when displaying continuations on job details page.

1.7.11
• Added – Display recurring job exceptions directly in the Dashboard UI.
• Added – Add built-in support for reliable shutdown detection of ASP.NET apps.
• Changed – Unify exception handling in recurring job scheduler.
• Changed – Internal feature to perform state changes without calling any filters.
• Changed – Decrease the number of retry attempts for recurring jobs to 5.
• Fixed – Let workers to ignore any state change filters when all previous attempts to call them failed.
• Fixed – Don't let `RecurringJobScheduler` to stall the pipeline when extension filters throw an exception.
• Fixed – Don't let `DelayedJobScheduler` to stall the pipeline when state filters throw an exception.
• Fixed – `JobLoadException` when new methods deployed, caused by overlapped recycles in ASP.NET applications.
• Fixed – Configuration changes aren't taken into account, caused by overlapped recycles in ASP.NET.
• Fixed – Zombie servers shown on the "Servers" page that aren't stopped automatically unless app pool is recycled.
• Fixed – Pass the whole exception to the `Error` field of a recurring job.
• Fixed – Re-schedule recurring jobs with unsupported versions, instead of stopping the pipeline.
• Fixed – Don't stumble over non-existing recurring jobs in a scheduler.
• Fixed – Add another check before removing non-existing jobs from delayed jobs to avoid race conditions.
• Fixed – Avoid throwing `NullReferenceException` instead of `InvalidOperationException` when deserializing a job.
• Fixed – Don't transform queue names to upper case in the Dashboard UI.

1.7.10
• Added – Farsi translation for Dashboard UI (by @sepehr1101).
• Added – Portuguese translation for Dashboard UI (by @GeErghon).
• Added – `PrefixPath` in `DashboardOptions` (by @shenjielx).
• Added – Allow `PageUrl` to be overridden by subclass (by @brendonparker).

1.7.9
• Fixed – Additional Chinese translation for Dashboard UI (by @brookqin).
• Fixed – Added `null` checks for expired failed jobs in Dashboard UI (by @ppkale1995-cimpress).
• Fixed – Add word break to definition lists for state cards in Dashboard UI.
• Fixed – Render long recurring job identifiers correctly in Dashboard UI.

1.7.8
• Added – `IGlobalConfiguration.UseResultsInContinuations` method to globally enable results for continuations.
• Added – Ability to push antecedent job's result to continuations via job parameters with `ContinuationsSupport`.
• Added – `JobParameterInjectionFilter` server filter to inject job parameters as arguments.
• Added – Allow to specify a custom thread factory in `UseBackgroundPool` methods.
• Changed – Add retry attempts for recurring jobs instead of immediately disabling them.
• Fixed – `CultureInfo.InvariantCulture` is now restored properly in background jobs.
• Fixed – Recurring jobs aren't triggered early after changing their cron expressions.
• Fixed – Don't trigger recurring job when it can't be scheduled due to errors.
• Fixed – Argument with a `null` value is skipped when displaying job arguments in Dashboard UI.
• Fixed – Add a workaround for resolving `System.Diagnostics.Debug` type in .NET Core 3.0.
• Deprecated – Deprecate the `JobActivatorScope.InnerScope` property as it wasn't implemented.

1.7.7

Core
• Changed – Produce a trace log message with details when updating a recurring job.
• Changed – Return early from `CoreBackgroundJobFactory.Create` when storage returns `null`.
• Project – Minor changes for the `Readme.md` file (by @231293).
• Project – Add `netcoreapp3.0` target framework for Hangfire.Core.Tests.
• Project – Add support for MSBuild 15.0 (VS 2019) when building `*.cshtml` files.

Dashboard UI
• Added – Allow modification of the Dashboard UI title (by @tbertenshaw).
• Added – Support for HTML tags on the Dashboard UI title (by @caioproiete).
• Added – Buttons for 1,000 and 5,000 items per page in dashboard.
• Added – Links to previous/next pages to the top of the dashboard page.
• Changed – Expose the `RazorPage.Context` property as a public member.
• Fixed – Supplementary Chinese translation (by @mccj).
• Fixed – Don't update real-time chart when too much time passed since the last update.

1.7.6
• Changed – Add support for dash characters (`-`) in queue names (by @caioproiete).
• Fixed – Show actual error in Dashboard UI when recurring job can't be scheduled.
• Fixed – Ensure backward compatibility when JSON payloads are serialized with field names only.
• Fixed – Non-awaited continuations can bring down the whole app when `TaskScheduler` is set to `null`.
• Fixed – Timeout value is not respected in some cases in the `WaitOneAsync` method.

1.7.5
• Fixed – Show error message when there's an error loading the statistics in Dashboard UI (by @prochnowc).
• Fixed – Properly handle recurring jobs with null or empty 'Job' field.
• Fixed – Disable recurring job when we can't schedule it due to an error.
• Fixed – Use `LazyThreadSafetyMode.PublicationOnly` to avoid caching "JobStorage.Current is null" exceptions.

1.7.4
• Added – `BackgroundJobClient.RetryAttempts` property to make job creation resilient to transient exceptions.
• Added – Dashboard localization support in `pt-BR` (by @candidodmv).
• Changed – Protect background dispatchers from moving from stopped state to non-stopped one.
• Changed – Unify `WaitOne` and `WaitOneAsync` methods with timeout and cancellation token for `WaitHandle` class.
• Fixed – Don't hide an original fatal exception occurred in dispatchers in some cases.
• Fixed – Dashboard UI to display "await" keyword on all task-like methods.
• Fixed – Display links properly in an informational message on the Servers page in Dashboard UI.
• Fixed – Wait for the heartbeat process before shutting down a server.

1.7.3

• SECURITY – Use `HtmlEncode` in all remaining places in Dashboard UI to prevent XSS attacks.

• Added – Added Dutch language, and updated missing translation on "Servers" page (by @r-win).
• Added – `Cron.Never` method for adding manual recurring jobs that never fire (by @michaltalaga).
• Fixed – Add missing `AddOrUpdate` extension methods for the `IRecurringJobManager` interface.
• Deprecated – Unused `HtmlHelper.FormatProperties` method is now obsolete.

1.7.2
• Added – `DashboardOptions.TimeZoneResolver` property to handle custom time zone resolvers in Dashboard UI.
• Fixed – `RecurringJob.AddOrUpdate` method is now able to update a broken recurring job.
• Fixed – Recurring job scheduler now properly handles recurring jobs whose job method or time zone is wrong.
• Fixed – Don't throw an exception on Recurring Jobs page when time zone can't be resolved.

1.7.1
• Added – `DashboardOptions.IgnoreAntiforgeryToken` property to disable token validation in Dashboard UI.
• Added – Display hints regarding server status on Servers page in Dashboard UI.
• Added – Highlight recurring jobs with no next execution in Dashboard UI.
• Added – Show actual error in Dashboard UI when recurring job has an invalid Cron expression.
• Fixed – `InvalidOperationException` when `AllowSynchronousIO` option isn't set in ASP.NET Core 3.0.
• Fixed – Set `NextExecution` value to `null` when existing recurring job has an invalid Cron expression.
• Fixed – Make dashboard charts to be more culture-specific to use correct time format.
• Fixed – Obsolete `UseSerializationSettings` comment now contains correct method name (by @PaitoAnderson).
• Project – `resx` files now re-generated automatically when building a project.

1.7.0
• Added – Full .NET Core 2.0 support by explicitly targeting .NET Standard 2.0.
• Added – `IGlobalConfiguration.SetDataCompatibilityLevel` to enable rolling upgrades from version 1.6.
• Added – `IGlobalConfiguration.UseRecommendedSerializerSettings` method for new installations.
• Added – Assemblies now loaded automatically when resolving a type when using default type resolver.
• Added – Custom `TaskScheduler` can now be specified in `BackgroundJobServerOptions` for workers.
• Added – `IdempotentCompletionAttribute` filter to enforce strict order for continuations.
• Added – `IBackgroundJobClient.ContinueJobWith` methods to replace `ContinueWith` ones in future for clarity.
• Added – `JobStorage.LinearizableReads` virtual property to avoid unnecessary waits in state changer.
• Added – Allow async methods to run their continuations on worker thread by disabling `TaskScheduler`.
• Added – Multi-stage shutdown to wait for graceful completion before starting to abort jobs.
• Added – Asynchronous checks for job cancellation, `IJobCancellationToken` can be replaced with `CancellationToken` (by @pieceofsummer).
• Added – Possibility to create millions of recurring jobs without stressing the scheduler.
• Added – Second-based recurring jobs are fully supported now with 6-part cron expressions.
• Added – Support for custom `TimeZoneInfo` resolvers in recurring jobs for interoperability purposes.
• Added – Package now explicitly targets .NET Standard 2.0, and .NET Framework 4.6 target added as well.
• Added – Type roundtrip support between .NET Core and .NET Framework for most common types.
• Added – Allow to specify queue names based on job arguments with `QueueAttribute` via patterns.
• Added – `PerformContext.Storage` property to allow server filters to spawn connections.
• Added – `GetFirstByLowestScoreFromSet` connection method overload that returns multiple items (by @cdschneider).
• Added – Entry point for custom job naming strategies available for dashboard (by @pieceofsummer).
• Added – `JobDisplayNameAttribute` class for displaying jobs in dashboard, available on .NET Core (by @pieceofsummer).
• Added – Support for async jobs returning ValueTask<T> (by @pieceofsummer).
• Added – Support for asynchronous background processes, opens the road toward async storage.
• Added – Circuit breaker pattern for background processes to reduce the logging pressure.
• Added – Processing server is now able to detect it was expired, and restart itself with the new id.
• Added – Ability to use custom delays for automatic retries of a background job.
• Added – `ThreadAbortException` and `ThreadInterruptedException` handling to keep the background process running.
• Added – Support for complex Cron expressions, including the `L`, `W`, `#` characters.
• Added – `JobActivator.BeginScope` method overload with the full `PerformContext` (by @jeroenvervaeke).
• Added – Support for read-only view for dashboard (by @mikechamberlain).
• Added – Storage property to control the job expiration time (by @rsilvanet).
• Added – Decrease the size of serialized type payloads and remove version information.
• Changed – Make `TaskScheduler.Default` the default scheduler for async jobs to avoid breaking changes.
• Changed – Split serializer setting to Internal and User scopes to isolate them (Version_170 Switch).
• Changed – Don't allow to affect internal serialization even by `JsonConvert.DefaultSettings` (Version_170 Switch).
• Changed – Share the same type binder between Hangfire itself and Newtonsoft.Json (Version_170 Switch).
• Changed – Use more compact representation of dates when using `SerializeDateTime` (Version_170 Switch).
• Changed – Stop using special case for `DateTime` argument serialization (Version_170 Switch).
• Changed – Don't serialize unused `AwaitingState.Expiration` field (Version_170 Switch).
• Changed – Specify parameter type when serializing arguments to allow using `TypeNameHandling.Auto` option.
• Changed – Use case sensitive search when resolving a type as by default in .NET.
• Changed – Make `SucceededState` constructor public to allow state serialization.
• Changed – Add `IBackgroundJobFactory.StateMachine` property (breaking change for low level API).
• Changed – Replace Rickshaw with Chart.js to have beautiful charts with less headache.
• Changed – `DelayedJobScheduler` is able to use the new storage method to query multiple jobs at once.
• Changed – `RecurringJobScheduler` now uses index-based checks to fetch only those jobs that should be scheduled.
• Fixed – Worker now logs an error, when all the state change attempts failed due to an exception.
• Fixed – Don't serialize arguments multiple times when showing job details in dashboard.
• Fixed – `DateTimeOffset` conversion error when it was serialized with `TypeConverter`.
• Fixed – Remove duplicate of argument deserialization code for obsolete `Job` class methods.
• Fixed – Decorate all the exceptions with the `SerializableAttribute`.
• Fixed – `ArgumentNullException` when job class contains method with non-resolvable generic arguments.
• Fixed – "Failed to initialize CoreCLR" error, by removing reference to `Microsoft.NETCore.Portable.Compatibility`.
• Fixed – Possible race conditions in `RecurringJobScheduler` that may lead to job duplicates.
• Fixed – Configuration inconsistency introduced in 1.6.18 leading to issues with custom `JobActivator`.
• Fixed – Triggering the recurring task doesn't update its last execution time.
• Fixed – Recurring job which don't have next execution (intentionally or not) don't cause exception.
• Fixed – Dashboard recurring jobs sorting is random (now it's based on next execution time).
• Fixed – Performance problems with huge amount of recurring jobs.
• Fixed – `NextExecution` field of a recurring job has delay in value getting set.
• Fixed – Dashboard graphs have improper sizing.
• Fixed – Server disappears from the list, but still performing the background processing.
• Fixed – Logging is too aggressive on transient errors.
• Fixed – Daylight saving time transitions now handled perfectly in recurring jobs thanks to Cronos.
• Fixed – Confusing Cron scheduling, when both day-of-week and day-of-month fields set.
• Project – Add `DataCompatibilityRangeFact` and `DataCompatibilityRangeTheory` classes for compatibility checks.
• Project – Reduce test execution time by removing unnecessary waits.