ReverseProxyHostedService.cs 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. using Microsoft.Extensions.Hosting;
  2. using Microsoft.Extensions.Logging;
  3. using System;
  4. using System.Diagnostics;
  5. using System.Threading;
  6. using System.Threading.Tasks;
  7. namespace FastGithub.ReverseProxy
  8. {
  9. /// <summary>
  10. /// 反向代理端口检测后台服务
  11. /// </summary>
  12. sealed class ReverseProxyHostedService : IHostedService
  13. {
  14. private readonly ILogger<ReverseProxyHostedService> logger;
  15. /// <summary>
  16. /// 反向代理端口检测后台服务
  17. /// </summary>
  18. /// <param name="logger"></param>
  19. public ReverseProxyHostedService(ILogger<ReverseProxyHostedService> logger)
  20. {
  21. this.logger = logger;
  22. }
  23. /// <summary>
  24. /// 服务启动时
  25. /// </summary>
  26. /// <param name="cancellationToken"></param>
  27. /// <returns></returns>
  28. public Task StartAsync(CancellationToken cancellationToken)
  29. {
  30. const int HTTPSPORT = 443;
  31. if (OperatingSystem.IsWindows())
  32. {
  33. if (TcpTable.TryGetOwnerProcessId(HTTPSPORT, out var pid))
  34. {
  35. try
  36. {
  37. Process.GetProcessById(pid).Kill();
  38. }
  39. catch (ArgumentException)
  40. {
  41. }
  42. catch (Exception)
  43. {
  44. var processName = Process.GetProcessById(pid).ProcessName;
  45. this.logger.LogError($"由于进程{processName}({pid})占用了{HTTPSPORT}端口,{nameof(FastGithub)}的反向代理无法工作");
  46. }
  47. }
  48. }
  49. return Task.CompletedTask;
  50. }
  51. /// <summary>
  52. /// 服务停止时
  53. /// </summary>
  54. /// <param name="cancellationToken"></param>
  55. /// <returns></returns>
  56. public Task StopAsync(CancellationToken cancellationToken)
  57. {
  58. return Task.CompletedTask;
  59. }
  60. }
  61. }