Резервное копирование базы данных с помощью Hangfire каждую минутуC#

Место общения программистов C#
Ответить Пред. темаСлед. тема
Anonymous
 Резервное копирование базы данных с помощью Hangfire каждую минуту

Сообщение Anonymous »

У нас есть служба Windows, которая каждое утро создает резервную копию базы данных. Теперь мы пытаемся создать резервную копию базы данных в виде сценария с C#, используя Hangfire. Наш план прост: создавать резервную копию каждое утро в определенное время. В качестве PoC я реализовал резервное копирование базы данных на бэкэнде, но каким-то образом застрял на запуске процесса в фоновом режиме с помощью Hangfire. В настоящее время я пытался создавать резервную копию каждую минуту в целях тестирования без каких-либо запросов http. Вот что я пробовал:

Код: Выделить всё

public static void RegisterApplicationServices(this IServiceCollection services, IConfiguration configuration)
{
services.AddControllers();

//Fetching Connection string from APPSETTINGS.JSON
var ConnectionString = configuration.GetConnectionString("DbConnectionString");

// Services
services.AddScoped();

// Repositories
services.AddScoped();

var sqlStorage = new SqlServerStorage(ConnectionString);

var options = new BackgroundJobServerOptions
{
ServerName = "Test Server"
};

JobStorage.Current = sqlStorage;

services.AddHangfire(configuration => configuration
.SetDataCompatibilityLevel(CompatibilityLevel.Version_170).UseSimpleAssemblyNameTypeSerializer()
.UseRecommendedSerializerSettings().UseSqlServerStorage(ConnectionString, new SqlServerStorageOptions
{
CommandBatchMaxTimeout = TimeSpan.FromMinutes(5),
SlidingInvisibilityTimeout = TimeSpan.FromMinutes(5),
QueuePollInterval = TimeSpan.Zero,
UseRecommendedIsolationLevel = true,
DisableGlobalLocks = true
}));

RecurringJob.AddOrUpdate("Database Backup", service => service.RunJob(), Cron.Minutely);

services.AddHangfireServer();
}
Сервис реализован следующим образом, работает нормально и проверяется с помощью http-запроса:

Код: Выделить всё

public class CustomJobService : IBackGroundJobService
{
private readonly ICustomJob _customJobRepository;

public CustomJobService(ICustomJob customJobRepository)
{
_customJobRepository = customJobRepository;
}

public async Task RunJob()
{
await Task.Run(() => _customJobRepository.RunJob());
}
}
Приведенный выше код работает, но не запускает службу каждую минуту для создания резервной копии. Чтобы это сделать, я написал следующее:

Код: Выделить всё

RecurringJob.AddOrUpdate("Database Backup", service => service.RunJob(), Cron.Minutely);
Есть ли какая-либо другая конфигурация, которую мне не хватает, или какой-либо способ реализовать вышеизложенное с помощью Hangfire без каких-либо запросов или запуска этого?

Подробнее здесь: https://stackoverflow.com/questions/791 ... ery-minute
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «C#»