using Microsoft.Extensions.Hosting; using Microsoft.Extensions.Logging; using System; using System.Threading; using System.Threading.Tasks; namespace FastGithub.DomainResolve { /// /// 域名解析后台服务 /// sealed class DomainResolveHostedService : BackgroundService { private readonly DnscryptProxy dnscryptProxy; private readonly IDomainResolver domainResolver; private readonly ILogger logger; private readonly TimeSpan dnscryptProxyInitDelay = TimeSpan.FromSeconds(5d); private readonly TimeSpan testPeriodTimeSpan = TimeSpan.FromSeconds(1d); /// /// 域名解析后台服务 /// /// /// public DomainResolveHostedService( DnscryptProxy dnscryptProxy, IDomainResolver domainResolver, ILogger logger) { this.dnscryptProxy = dnscryptProxy; this.domainResolver = domainResolver; this.logger = logger; } /// /// 后台任务 /// /// /// protected override async Task ExecuteAsync(CancellationToken stoppingToken) { try { await this.dnscryptProxy.StartAsync(stoppingToken); await Task.Delay(dnscryptProxyInitDelay, stoppingToken); while (stoppingToken.IsCancellationRequested == false) { await this.domainResolver.TestSpeedAsync(stoppingToken); await Task.Delay(this.testPeriodTimeSpan, stoppingToken); } } catch (OperationCanceledException) { } catch (Exception ex) { this.logger.LogError(ex, "域名解析异常"); } } /// /// 停止服务 /// /// /// public override Task StopAsync(CancellationToken cancellationToken) { this.dnscryptProxy.Stop(); return base.StopAsync(cancellationToken); } } }