BaseClearServicce.cs 3.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. using Microsoft.Extensions.Hosting;
  2. using Serilog;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.Linq;
  6. using System.Text;
  7. using System.Threading.Tasks;
  8. namespace DW5S.WebApi
  9. {
  10. /// <summary>
  11. /// 基础清理服务(负责upload目录的清理,不会清理NotClear目录及其文件)
  12. /// </summary>
  13. public class BaseClearService : BackgroundService
  14. {
  15. private readonly string dir = "upload";
  16. private readonly ILogger logger;
  17. public BaseClearService(ILogger logger)
  18. {
  19. this.logger = logger;
  20. }
  21. /// <summary>
  22. ///
  23. /// </summary>
  24. /// <param name="stoppingToken"></param>
  25. /// <returns></returns>
  26. protected override async Task ExecuteAsync(CancellationToken stoppingToken)
  27. {
  28. await Task.Delay(5000, stoppingToken);//延迟一会儿让webbapi先启动
  29. logger.Information($"启动通用目录{dir}数据清理功能...");
  30. await Task.Run(async () =>
  31. {
  32. while (!stoppingToken.IsCancellationRequested)
  33. {
  34. Clear();
  35. //5分钟扫描一次
  36. await Task.Delay(600 * 1000, stoppingToken);
  37. }
  38. //程序退出时强制删除所有
  39. try
  40. {
  41. Directory.Delete(dir, true);
  42. }
  43. catch
  44. { }
  45. }, stoppingToken);
  46. }
  47. private void Clear()
  48. {
  49. #region 清理空目录
  50. string clearDir = Path.Combine(AppContext.BaseDirectory, dir);
  51. try
  52. {
  53. var dirs = Directory.EnumerateDirectories(clearDir, "*", SearchOption.AllDirectories);
  54. foreach (var item in dirs)
  55. {
  56. if (item.ToLower().Contains("notclear")) continue;
  57. DirectoryInfo dir = new DirectoryInfo(item);
  58. if (dir.EnumerateFiles().Any()) continue;
  59. //删除5分钟以前创建的空目录
  60. if ((DateTime.Now - dir.CreationTime).TotalMinutes > 5)
  61. {
  62. dir.Delete();
  63. }
  64. }
  65. }
  66. catch (Exception ex)
  67. {
  68. logger.Error(ex, $"删除{dir}目录中的空目录出错");
  69. }
  70. #endregion
  71. #region 清理30分钟以前上传的文件
  72. var files = Directory.EnumerateFiles(clearDir, "*", SearchOption.AllDirectories);
  73. foreach (var item in files)
  74. {
  75. if (item.ToLower().Contains("notclear")) continue;
  76. FileInfo f = new FileInfo(item);
  77. if ((DateTime.Now - f.LastWriteTime).TotalMinutes > 30)
  78. {
  79. try
  80. {
  81. f.Delete();
  82. }
  83. catch (Exception ex)
  84. {
  85. logger.Error(ex, $"$删除{dir}目录中文件[{f.Name}]失败");
  86. }
  87. }
  88. }
  89. #endregion
  90. }
  91. }
  92. }