Skip to content

Latest commit

 

History

History
376 lines (300 loc) · 13 KB

ChangeLog.md

File metadata and controls

376 lines (300 loc) · 13 KB

Change log

v1.11.2

  • Minor tweaks to migration
  • Dont delete migration lock on shutdown
  • Update to Hangfire.Core 1.8.16
  • TargetFrameworks is set to net472 and netstandard2.1

v1.11.1

  • Fix not creating package for net472
  • Update to Hangfire.Core 1.8.15

v1.11.0

  • Update to MongoDB 3.0 (by ChrisMcKee)

v1.10.8

  • Update to MongoDB 2.28.0 (by DavidLievrouw)

v1.10.7

  • Update to Hangfire 1.8.14
  • Update to MongoDB 2.26.0

v1.10.6

  • Update to MongoDB 2.25.0
  • Support for migrating down when using 'drop' migration strategy (#393)
  • Fix deserialization of missing nullable fields (by jkla-dr) (#395)

v1.10.5

  • Update to Hangfire 1.8.12
  • Support for Stable API (strict) #387

v1.10.4

  • Update to Hangfire 1.8.11
  • Update to MongoDB 2.24.0

v1.10.3

  • Fixes bug for SlidingInvisibilityTimeout, should only do heartbeats for processing jobs

v1.10.2

  • Dont use db server time for distributed lock timeout. Will addressed in a later release

v1.10.1

  • Use $addFields operator instead of $set when setting DistributedLock heartbeat for support mongo versions < 4.2

v1.10.0

  • Update to Hangfire 1.8.9
  • Use SlidingInvisibilityTimeout to determine whether a background job is still alive
  • BREAKING: Remove InvisibilityTimeout
  • Use server time for distributed lock instead of Datetime.UtcNow
  • Fixed Job not requeued when requeued while in processing state (#380)

v1.9.16

  • Update to Hangfire 1.8.7
  • Update to MongoDB 2.23.1

v1.9.15

  • Fix Slow operations reported by Atlas #374
  • Fix Dashboard does not show exception for retries #375

v1.9.14

  • Add index needed for improved performance of MongoMonitoringApi.GetQueues

v1.9.13

  • Improve performance of MongoMonitoringApi.GetQueues()

v1.9.12

  • Update to Hangfire 1.8.6
  • Update to MongoDB 2.22.0
  • Add recommended indexes (#368)

v1.9.11

  • Add flag for disable all logic related to capped collections. (will disable TailNotificationsCollection strategy)

v1.9.10

  • Fix CosmosDB duplicate key error #362

v1.9.9

  • Fix Jobs queued directly when queue is specified when scheduling #359

v1.9.8 (2023-08-14)

v1.9.7 (2023-07-11)

  • Update to Hangfire.Core 1.8.3
  • Update to MongoDB.Driver 2.20.0
  • Fix using local server time for server heartbeats #356

v1.9.6 (2023-06-12)

  • Update to Hangfire.Core 1.8.2
  • Update to MongoDB.Driver 2.19.2

v1.9.5 (2023-05-18)

  • Update to Hangfire.Core 1.8.1

v1.9.4 (2023-05-08)

  • Update to Hangfire.Core 1.8.0

v1.9.3 (2023-03-31)

  • Update to Hangfire.Core 1.7.34
  • Update to MongoDB.Driver 2.19.1

v1.9.2 (2022-02-02)

  • Remove debug log written with Console.WriteLine (#336)
  • Automatically run MongoDB during the tests (with EphemeralMongo) (#337)
  • Make compatible with MongoDB.Driver linq v3 (#338)
  • Update to Hangfire.Core 1.7.33
  • Update MongoDB.Driver to 2.19.0

v1.9.1 (2022-12-19)

  • Fixes SchemaDto deserialization bug (#333)

v1.9.0 (2022-12-10)

  • Update to Hangfire.Core 1.7.32
  • Update MongoDB.Driver to 2.18.0
  • Using manual serialization to not be subject to serializer conventions (#328)
  • Returns IGlobalConfiguration instead of MongoStorage in all UseMongoStorage (#317)
  • Added indexes (#330)
  • Merge JobQueueDto fields into JobDto (schema change, requires migration)

v1.7.3 (2022-08-24)

  • Fix hardcoded timeout in MongoConnectException message (#315)
  • Update to Hangfire.Core 1.7.31
  • Update MongoDB.Driver to 2.17.1

v1.7.2 (2022-06-13)

  • Update to Hangfire.Core 1.7.30

v1.7.1 (2022-06-08)

  • Update to Hangfire.Core 1.7.29
  • Update to MongoDB.Driver 2.16.0

v1.7.0

  • Fix jobqueue entity deleted if job times out (#307)
  • Documented usage of CheckQueuedJobsStrategy in Readme (thanks corentinaltepe) (#300)
  • Update version to only match Hangfire.Core Major.Minor

v0.7.28

  • Update to latest Hangfire (v1.7.28)
  • Replace MongoClient for IMongoClient #301
  • Better error description for 'CheckQueuedJobsStrategy'

v0.7.27

  • Update to latest Hangfire (v1.7.27)
  • Dont notify distributed lock released, too noisy.
  • Add support for change streams (watch).
  • Remove transactions, issues with write conflicts and performance. schema supports bulk writes just fine.
  • NotificationsObserver will try to convert 'notifications' collection to capped if dropped.

v0.7.25

  • Update to latest Hangfire.Core (v1.7.25)
  • Fixes job queue semaphore not blocking if released queue not used on current node (#284)

v0.7.24

  • Update to latest Hangfire.Core (v1.7.24)
  • Update to latest Mongo drivers (v2.13.1)
  • Update README.md. Includes the note about the parameter InvisibilityTimeout of the MongoStorageOptions. (#280)
  • Heartbeat method should throw a BackgroundServerGoneException when a given server does not exist (#287)
  • Remove Obsolete attributes for specifying database name. (#285)

v0.7.22

  • Update to latest Hangfire.Core (v1.7.22)
  • Update to latest Mongo drivers (v2.12.2)
  • Add support for mongodb transactions (Bulkwrite still default, setup in options)
  • Add CosmosDB support (BETA)
  • Dont stop Notifications Observer on failure, added 5s backoff instead, max timeout = 60s

v0.7.20

  • Update to latest Hangfire.Core (v1.7.20)
  • Update to latest Mongo drivers (v2.12.1)
  • Remove Newtonsoft dependency
  • Add possibility to opt out of using capped collection/tailable cursor
  • Optimizations to WriteOnlyTransaction filters when filtering on unique index
  • Optimizations to queries for scheduled and recurrent jobs

v0.7.19

  • Update to latest Hangfire.Core (v1.7.19)
  • Update to latest Mongo drivers (v2.11.6)
  • Simplify semaphore logic and support more than 64 waithandles (#264)
  • Fixed issue caused by StringIdStoredAsObjectIdConvention() mongo convention (#267)

v0.7.17

  • Update to latest Hangfire.Core (v1.7.17)
  • Update to latest Mongo drivers (v2.11.4)
  • Only targeting netstandard2.0
  • Remove ASP.NET sample
  • Fix collection backup requires dbadmin role (#253)
  • Adds bypass migration flag to MongoStorageOptions (#256)

v0.7.12

  • Update to latest Hangfire.Core (v1.7.12)
  • Update to latest Mongo drivers (v2.11.0)
  • Add index (PR #247)

v0.7.11

  • Align version number with Hangfire.Core
  • Update dependencies
    • target netstandard2.0
    • "MongoDB.Driver" Version="2.10.4"
    • "Hangfire.Core" Version="1.7.11"
  • Make extendable
    • Everything can now be hooked into and extended

v0.6.7

  • InvisibilityTimeout computed for each query (#224)
  • Update dependencies
    • target netstandard2.0
    • "MongoDB.Driver" Version="2.10.2"
    • "Hangfire.Core" Version="1.7.9"

v0.6.6

  • Add support for specifying the database name in the connection string (#219)
  • InvisibilityTimeout should not be obsolete (#220)

v0.6.5

  • Cleanup expired DistributedLock after each wait iteration (#217)
  • Make extracting mongodb version more resilient

v0.6.4

  • Upgrade to "Hangfire.Core" Version="1.7.6"
  • Upgrade to "MongoDB.Bson" Version="2.9.1"
  • Upgrade to "MongoDB.Driver" Version="2.9.1"
  • Upgrade to "MongoDB.Driver.Core" Version="2.9.1"
  • Make sure to use timout when waiting for signalled semaphore #207
  • Do not try to delete expired migration lock #208
  • Allow user to supply preconfigured MongoClient #199
  • Dont restart observing capped collection if collection is not capped (deleted by user) #204
  • Fix job set filter - escape regex chars #212

v0.6.3

  • Explicitly set discriminators because filters rely on them (#200)

v0.6.2

  • Handle cancellation more gracefully (#191)
  • Make Connection check timeout configurable and set new default = 5 seconds (#191)

v0.6.1

  • Fixed potential race condition releasing distributed lock mutex (#188)

v0.6.0

  • Added connection check when initializing MongoStorage (#179)
  • Fixed Jobs Stuck In 'Enqueued' State (#180)
  • Added Tailable collection 'notifications' for signalling enqueued jobs and released locks
  • Update to latest Hangfire.Core (v1.7.1)
  • Update to latest Mongo.Driver (v2.8.0)
  • Target net452 as this is required by latest Mongo.Driver
  • Added dedicated migration lock.
  • Fix old migration step. (only used if migrating from an old schema)
  • Enhanced logging

v0.5.15

  • Fix Dashboard, top menu, Recurring Jobs count is 0 (#173)
  • Fix GetAllItemsFromSet truncated values (#175)

v0.5.14

  • Fix race case in distributed lock implementation (#166, #134)
  • Not JSON serializing Server data
  • Add unique index ('Key') for 'Hash' and 'Counter' data (related to #166)
  • Rename 'ListDto' field 'Key' to 'Item' ('Key' is now a unique index) (related to #166)
  • Remove obsolete counters, which should have been removed in migrations for schema 13
  • Mark ctor's for MongoStorage which takes connectionString obsolete, use 'MongoClientSettings'
  • Fix requeued job state can be incorrect when multiple servers process jobs (#167)
  • Add console logging per default in samples

v0.5.13

  • Use 'buildinfo' command instead of 'serverStatus' to get the server version. Because the 'buildinfo' command does not require - root privileges.
  • Add missing migration for HashDto.Field removal
  • Add data integrity tests
  • Update to "MongoDB.Driver" Version="2.7.2"
  • Update to "Hangfire.Core" Version="1.6.21"
  • Use separate collection for migration locks as the ".locks" collection might be dropped by if the migration strategy is "Drop"
  • Making migration support CosmosDB
  • Fix if client is using camelcase convention
  • Removing Obsolete interfaces and logic
  • Obsolete access to DbContext and queue providers
  • Fix migration option combi migrationstrategy.drop and backupstrategy.none
  • Fix timezone issue with conflicting bsonserializer settings

v0.5.12

  • Using $dec and $inc operators for counters
  • Merging HashDto fields into one document
  • Deprecating direct db access and queueproviders
  • Removed use of $slice (#151)

v0.5.11

  • Fixed duplicate key exception in advanced setups (#70)
  • Fixed DeadLock on concurrent environment (#139)
  • Update to latest Hangfire
  • Update to latest MongoDB

v0.5.10

  • Fix for Hangfire Dashboard History Graph showing incorrect counts
  • Update to latest Hangfire
  • Update to latest MongoDB

v0.5.9

  • Fix for Hangfire Dashboard History Graph showing incorrect counts
  • Added indexes to all our collections
  • Updated a few NuGet references
  • Cleaned up library references
  • Improve migration stability
  • Remove dependency to Microsoft.CSharp

v0.5.8

  • Broken release

v0.5.7

  • Fix for broken migration

v0.5.6

  • Job state now shows correct in dashboard
  • Hangfire dashboard logs are now sorted descending

v0.5.5

  • Use default naming conventions for our Dto models
    This should hopefully eliminate all the camelCase issues
  • Optimized job aggregation to filter by only the status needed
  • Add version check when backing up collections

v0.5.4

  • Fix broken migration

v0.5.3

  • Added new backup database strategy when migration
  • Fixed a bug that made backup incompatiple with MongoDB 3.4
  • A few code optimizations

v0.5.2

  • Forcing the use of Pascal Casing in Hangfire specific collections. See README.md for more info.

v0.5.1

  • Fix for migration of stateData collelction.

v0.5.0

  • Migration has been introduces. So now you can upgrade from previous version without loosing you jobs.
  • MonitoringApi returning succeeded jobs when quering processing
  • List and Set not sorted correctly
  • Fixed NuGet references for xUnit so they again can be run from IDE
  • Updated Hangfire NuGet reference to latest (Hangfire 1.6.15)
  • Updated project files so it is possible to build and run .NETCore sample from Visual Studio Code
  • Using MongoWriteOnlyTransaction.SetRangeInHash in MongoConnection.SetRangeInHash

v0.4.1

  • Add workaround for MongDB C# driver not adding inheritance types when doing upsert
    • (We have filed a bug report with MongoDB)
  • Fix bug in MongoWriteOnlyTransaction.AddRangeToSet where Value not being written for upsert

v0.4.0 *** BREAKING CHANGES ***

  • Combined collections for state data into one collection
  • Optimized job creation
    • Not getting timestamp from mongodb. Using Datetime.UtcNow
    • Using MongoDB native "ObjectId" as JobId instead of int.

Why did you do this?

We currently have issues regarding atomicity in our "JobStorageTransaction" implemention. In order to address this we are combining this information into one collection in order to do bulk writes. (We have not yet fixed our "JobStorageTransaction", but we will addres those for next release)

What should I do?

You have to drop your jobs db.

Other changes/fixes

  • Fix MongoStorage.ToString() when settings contain multiple servers
  • Upgraded to VS2017, new csproj and MSBuild
  • Fix for duplicated key error writing schema version
  • Update to JobDto, added parameters and statehistory to JobDto

Whats next

  • Fixes for Hangfire.Pro features
  • ReactiveMongoStorage utilizing capped collections, no need to poll.