Asp.Net Core で、定時実行するJob、バックグラウンドタスク を実装するなら、Cronos nugetパッケージを使うと、実装が断然楽になるのでお勧め。
githubに実装サンプルがあり、そのソースコードをコピーペーストすれば実装も直ぐ終わる。
Schedule Cron Jobs using HostedService in ASP.NET Core に詳しい実装説明がある。
How should I inject a DbContext instance into an IHostedService? の方法で、DB処理も簡単に実装できる。
組み込み手順
1.Cronos nugetパッケージをインストールする。
3.サンプルソースのServiceWorkerCronJobDemoプロジェクトから主なソースを、本ソースへコピーする。
3-1.Startup.cs
ConfigureServices()にAddCronJob()コピーし、実行時間だけ修正する。
1 2 3 4 5 6 7 |
services.AddCronJob<MyCronJob1>(c => { c.TimeZoneInfo = TimeZoneInfo.Local; c.CronExpression = @"*/5 * * * *"; }); |
3-2.CronJobService.cs
CronJobService.cs をまるごとコピーし、namespaceだけ合わせる。
3-3.MyCronJob1.cs
MyCronJob1 .cs をまるごとコピーし、namespaceを合わせ、DoWork()内に個別の実行処理を追加する。
DB処理が必要な場合、このように修正する。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 |
using System; using System.Threading; using System.Threading.Tasks; using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.Logging; namespace ServiceWorkerCronJobDemo.Services { public class MyCronJob1 : CronJobService { private readonly IServiceScopeFactory scopeFactory; private readonly ILogger<MyCronJob1> _logger; public MyCronJob1(IScheduleConfig<MyCronJob1> config, ILogger<MyCronJob1> logger, IServiceScopeFactory scopeFactory) : base(config.CronExpression, config.TimeZoneInfo) { _logger = logger; } public override Task StartAsync(CancellationToken cancellationToken) { _logger.LogInformation("CronJob 1 starts."); return base.StartAsync(cancellationToken); } public override Task DoWork(CancellationToken cancellationToken) { _logger.LogInformation($"{DateTime.Now:hh:mm:ss} CronJob 1 is working."); using (var scope = scopeFactory.CreateScope()) { var dbContext = scope.ServiceProvider.GetRequiredService<ApplicationDbContext>(); // DB処理 // } return Task.CompletedTask; } public override Task StopAsync(CancellationToken cancellationToken) { _logger.LogInformation("CronJob 1 is stopping."); return base.StopAsync(cancellationToken); } } } |
コメント