OnlineUserJob.cs 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. // 大名科技(天津)有限公司 版权所有
  2. //
  3. // 此源代码遵循位于源代码树根目录中的 LICENSE 文件的许可证
  4. //
  5. // 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动
  6. //
  7. // 任何基于本项目二次开发而产生的一切法律纠纷和责任,均与作者无关
  8. using Furion.Logging.Extensions;
  9. namespace Admin.NET.Core;
  10. /// <summary>
  11. /// 清理在线用户作业任务
  12. /// </summary>
  13. [JobDetail("job_onlineUser", Description = "清理在线用户", GroupName = "default", Concurrent = false)]
  14. [PeriodSeconds(1, TriggerId = "trigger_onlineUser", Description = "清理在线用户", MaxNumberOfRuns = 1, RunOnStart = true)]
  15. public class OnlineUserJob : IJob
  16. {
  17. private readonly IServiceScopeFactory _scopeFactory;
  18. private readonly ILogger _logger;
  19. public OnlineUserJob(IServiceScopeFactory scopeFactory, ILoggerFactory loggerFactory)
  20. {
  21. _scopeFactory = scopeFactory;
  22. _logger = loggerFactory.CreateLogger("System.Logging.LoggingMonitor");
  23. }
  24. public async Task ExecuteAsync(JobExecutingContext context, CancellationToken stoppingToken)
  25. {
  26. using var serviceScope = _scopeFactory.CreateScope();
  27. var rep = serviceScope.ServiceProvider.GetRequiredService<SqlSugarRepository<SysOnlineUser>>();
  28. await rep.CopyNew().AsDeleteable().ExecuteCommandAsync(stoppingToken);
  29. var originColor = Console.ForegroundColor;
  30. Console.ForegroundColor = ConsoleColor.Red;
  31. Console.WriteLine("【" + DateTime.Now + "】清空在线用户列表");
  32. Console.ForegroundColor = originColor;
  33. // 缓存租户列表
  34. await serviceScope.ServiceProvider.GetRequiredService<SysTenantService>().CacheTenant();
  35. // 自定义日志
  36. _logger.LogInformation("服务已重启...");
  37. }
  38. }