查看 source code ,StopAsync 的默认超时为 5 秒。
WebHostBuilder 提供了一个扩展方法 UseShutdownTimeout 方便设置。但是 对于 HostBuilder 不存在这样的等价物。
我知道我可能通过想要超过 5 秒的超时来滥用 HostBuilder 的意图,但它是一个很好的框架,用于管理一组相互依赖的作业。
我真的很感谢一些关于如何使用 HostBuilder 的指导,就像 UseShutdownTimeout 对 WebHostBuilder 所做的那样,同时仍然使用官方 NuGet 包。我看了一下可能扩展 HostingAbstractionsHostBuilderExtensions 但它是一个静态类......
下面的示例控制台应用程序用于触发 StopAsync OperationCanceledException 事件。只需在 10 秒之前按 Ctrl+C。
using System;
using System.Threading;
using System.Threading.Tasks;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
namespace StackOverflow_GenericHost_StopAsync
{
class Program
{
static async Task Main(string[] args)
{
var host = new HostBuilder()
.ConfigureServices((hostContext, services) =>
{
services.AddSingleton<IHostedService, MustRunToCompletionService>();
})
.Build();
await host.StartAsync();
try
{
await host.WaitForShutdownAsync();
}
catch (OperationCanceledException ex)
{
// We have completed a controlled shutdown but the Exception is ugly
Console.WriteLine(ex);
Console.ReadKey();
}
// just hangs if we don't
host.Dispose();
}
}
class MustRunToCompletionService : IHostedService
{
private Task _longRunningTask;
private async Task MustCompleteProcess()
{
// simulate long running job
Thread.Sleep(15000);
}
public Task StartAsync(CancellationToken cancellationToken)
{
_longRunningTask = Task.Run(MustCompleteProcess);
return Task.CompletedTask;
}
public Task StopAsync(CancellationToken cancellationToken)
{
// ignore cancellationToken, I really need this to run to completion
return Task.WhenAll(_longRunningTask);
}
}
}
最佳答案
感谢这篇关于 SuppressStatusMessages 的帖子,我收集到了答案
.ConfigureServices((hostContext, services) =>
{
services.Configure<HostOptions>(o => o.ShutdownTimeout = TimeSpan.FromSeconds(90));