mirror of
https://github.com/DrizzleTime/Foxel.git
synced 2026-05-12 02:20:28 +08:00
32 lines
1.0 KiB
C#
32 lines
1.0 KiB
C#
namespace Foxel.Services.Background;
|
|
|
|
public class QueuedHostedService(
|
|
ILogger<QueuedHostedService> logger,
|
|
IServiceProvider serviceProvider)
|
|
: BackgroundService
|
|
{
|
|
protected override async Task ExecuteAsync(CancellationToken stoppingToken)
|
|
{
|
|
logger.LogInformation("后台队列处理服务已启动");
|
|
|
|
try
|
|
{
|
|
// 从数据库恢复未完成的任务
|
|
using var scope = serviceProvider.CreateScope();
|
|
var backgroundTaskQueue = scope.ServiceProvider.GetRequiredService<IBackgroundTaskQueue>();
|
|
await backgroundTaskQueue.RestoreUnfinishedTasksAsync();
|
|
logger.LogInformation("已完成未处理任务的恢复");
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
logger.LogError(ex, "恢复未完成任务时出错");
|
|
}
|
|
|
|
while (!stoppingToken.IsCancellationRequested)
|
|
{
|
|
await Task.Delay(1000, stoppingToken);
|
|
}
|
|
logger.LogInformation("后台队列处理服务已停止");
|
|
}
|
|
}
|