.NET ジェネリックホストの使用
.NET ジェネリックホストは .NET Core アプリケーションのホストと実行を行うライブラリです。これにより、アプリケーションのライフサイクル、依存関係の挿入、ロギングなどの機能の構成と管理が容易になります。
.NET での一般的なホストを使用するための基本的な手順を以下に示します。
- 新しい.NET Core コンソールアプリケーションプロジェクトを作成します。
- プロジェクトの .csproj ファイルに次のパッケージ参照を追加してください。
<ItemGroup>
<PackageReference Include="Microsoft.Extensions.Hosting" Version="3.1.0" />
</ItemGroup>
- Program.csファイルに次のコードを追加してください。
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
namespace YourAppName
{
class Program
{
static void Main(string[] args)
{
CreateHostBuilder(args).Build().Run();
}
static IHostBuilder CreateHostBuilder(string[] args) =>
Host.CreateDefaultBuilder(args)
.ConfigureServices((hostContext, services) =>
{
// 添加你的服务
services.AddHostedService<YourService>();
});
}
}
CreateHostBuilderメソッドはIHostBuilderインスタンスを作成し、ConfigureServicesメソッドは依存関係挿入サービスを設定します。
- たとえば「YourService.cs」のように、IHostedServiceインターフェイスを実装するサービスクラスを作成します。
using System;
using System.Threading;
using System.Threading.Tasks;
using Microsoft.Extensions.Hosting;
using Microsoft.Extensions.Logging;
namespace YourAppName
{
public class YourService : IHostedService, IDisposable
{
private readonly ILogger<YourService> _logger;
private Timer _timer;
public YourService(ILogger<YourService> logger)
{
_logger = logger;
}
public Task StartAsync(CancellationToken cancellationToken)
{
_timer = new Timer(DoWork, null, TimeSpan.Zero, TimeSpan.FromSeconds(5));
return Task.CompletedTask;
}
private void DoWork(object state)
{
_logger.LogInformation("执行工作...");
}
public Task StopAsync(CancellationToken cancellationToken)
{
_timer?.Change(Timeout.Infinite, 0);
return Task.CompletedTask;
}
public void Dispose()
{
_timer?.Dispose();
}
}
}
このカテゴリでは、IHostedServiceインターフェースによって実装されるStartAsyncとStopAsyncメソッドが利用され、アプリケーションの起動と停止時に対応するロジックを実行します。
- アプリを実行すると5秒間隔でログ情報が出力されることがわかるでしょう。
以上で.NETのジェネリックホストを使用する基本的な手順となります。ご自分のニーズに合わせて、さらにサービスやロジックを追加してください。