让 Hangfire 使用 MongoDB 存储

存储 存储软件 MongoDB
MongoDB 支持Hangfire库。通过使用这个库,您可以将所有作业信息存储在 MongoDB 中。要安装 Hangfire MongoDB Storage,请在 Nuget 包管理器控制台中运行以下命令。

[[413350]]

本文转载自微信公众号「后端Q  」,作者conan 。转载本文请联系后端Q  公众号。

MongoDB 支持Hangfire库。通过使用这个库,您可以将所有作业信息存储在 MongoDB 中。

要安装 Hangfire MongoDB Storage,请在 Nuget 包管理器控制台中运行以下命令:

  1. PM> Install-Package Hangfire.Mongo 
  1. public void ConfigureServices(IServiceCollection services) 
  2.     var mongoUrlBuilder = new MongoUrlBuilder("mongodb://localhost/jobs"); 
  3.     var mongoClient = new MongoClient(mongoUrlBuilder.ToMongoUrl()); 
  4.  
  5.     // Add Hangfire services. Hangfire.AspNetCore nuget required 
  6.     services.AddHangfire(configuration => configuration 
  7.         .SetDataCompatibilityLevel(CompatibilityLevel.Version_170) 
  8.         .UseSimpleAssemblyNameTypeSerializer() 
  9.         .UseRecommendedSerializerSettings() 
  10.         .UseMongoStorage(mongoClient, mongoUrlBuilder.DatabaseName, new MongoStorageOptions 
  11.         { 
  12.             MigrationOptions = new MongoMigrationOptions 
  13.             { 
  14.                 MigrationStrategy = new MigrateMongoMigrationStrategy(), 
  15.                 BackupStrategy = new CollectionMongoBackupStrategy() 
  16.             }, 
  17.             Prefix = "hangfire.mongo"
  18.             CheckConnection = true 
  19.         }) 
  20.     ); 
  21.     // Add the processing server as IHostedService 
  22.     services.AddHangfireServer(serverOptions => 
  23.     { 
  24.         serverOptions.ServerName = "Hangfire.Mongo server 1"
  25.     }); 
  26.  
  27.     // Add framework services. 
  1. var options = new MongoStorageOptions 
  2.     MigrationOptions = new MongoMigrationOptions 
  3.     { 
  4.         MigrationStrategy = new DropMongoMigrationStrategy(), 
  5.         BackupStrategy = new NoneMongoBackupStrategy() 
  6.     } 
  7. }; 
  8. GlobalConfiguration.Configuration.UseMongoStorage("mongodb://localhost/jobs", options); 
  9. app.UseHangfireServer(); 
  10. app.UseHangfireDashboard(); 

Throw

这是默认的迁移策略。如果架构版本不匹配,它将抛出InvalidOperationException,永远不会让您启动并运行。因此,它迫使您决定什么迁移策略最适合您,同时确保数据的安全。

Drop

这只需删除现有的Hangfire.Mongo数据库并更新模式版本。没有绒毛,准备从头开始。这是一个完美的策略,如果你在创业时把所有的工作都安排好。

Migrate

这将把数据库从一个模式版本迁移到下一个模式版本,直到达到所需的模式版本。并不是所有的数据都可以迁移,这就是为什么会发生一些数据丢失的原因。在投入生产前,请谨慎使用并仔细测试。我们不对数据丢失负责。

注意:只支持前向迁移。如果需要还原到以前的架构版本,则需要手动删除或还原以前的数据库。

https://github.com/sergeyzwezdin/Hangfire.Mongo

 

责任编辑:武晓燕 来源: 后端Q
相关推荐

2018-09-17 10:47:28

MongoDB存储Docker

2015-04-02 12:42:26

HDFS分层存储高效

2021-06-30 00:20:12

Hangfire.NET平台

2014-12-17 10:54:14

MongoDB

2015-12-29 17:06:17

大数据存储

2022-11-01 08:02:04

2019-03-18 14:58:18

RedisMySQLMongoDB

2012-04-19 10:04:20

ibmdw

2013-01-28 11:34:11

云对象存储大数据分析对象存储

2021-12-14 15:03:58

LVM系统运维

2023-04-28 07:56:09

2011-06-08 10:30:08

MongoDB

2019-12-31 09:33:03

MongoDBB 树NoSQL

2023-10-09 07:31:25

2012-12-13 10:17:25

2020-08-12 18:11:02

戴尔

2010-08-20 09:09:24

MongoDB

2012-05-21 09:07:55

云存储

2018-03-21 08:46:11

存储网络数据

2009-05-08 13:46:38

JavaScriptHTML5离线存储
点赞
收藏

51CTO技术栈公众号