DnscryptProxyHostedService.cs 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. using Microsoft.Extensions.Hosting;
  2. using Microsoft.Extensions.Logging;
  3. using System;
  4. using System.Threading;
  5. using System.Threading.Tasks;
  6. namespace FastGithub.DomainResolve
  7. {
  8. /// <summary>
  9. /// DnscryptProxy后台服务
  10. /// </summary>
  11. sealed class DnscryptProxyHostedService : BackgroundService
  12. {
  13. private readonly ILogger<DnscryptProxyHostedService> logger;
  14. private readonly DnscryptProxy dnscryptProxy;
  15. /// <summary>
  16. /// DnscryptProxy后台服务
  17. /// </summary>
  18. /// <param name="dnscryptProxy"></param>
  19. /// <param name="logger"></param>
  20. public DnscryptProxyHostedService(
  21. DnscryptProxy dnscryptProxy,
  22. ILogger<DnscryptProxyHostedService> logger)
  23. {
  24. this.dnscryptProxy = dnscryptProxy;
  25. this.logger = logger;
  26. }
  27. /// <summary>
  28. /// 启动dnscrypt-proxy
  29. /// </summary>
  30. /// <param name="stoppingToken"></param>
  31. /// <returns></returns>
  32. protected override async Task ExecuteAsync(CancellationToken stoppingToken)
  33. {
  34. try
  35. {
  36. await this.dnscryptProxy.StartAsync(stoppingToken);
  37. }
  38. catch (Exception ex)
  39. {
  40. this.logger.LogWarning($"{this.dnscryptProxy}启动失败:{ex.Message}");
  41. }
  42. }
  43. /// <summary>
  44. /// 停止dnscrypt-proxy
  45. /// </summary>
  46. /// <param name="cancellationToken"></param>
  47. /// <returns></returns>
  48. public override Task StopAsync(CancellationToken cancellationToken)
  49. {
  50. try
  51. {
  52. this.dnscryptProxy.Stop();
  53. }
  54. catch (Exception ex)
  55. {
  56. this.logger.LogWarning($"{this.dnscryptProxy}停止失败:{ex.Message}");
  57. }
  58. return base.StopAsync(cancellationToken);
  59. }
  60. }
  61. }