HeartBeatCheckJob.cs 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. using EVCB_OCPP.Domain;
  2. using EVCB_OCPP.WSServer.Service.DbService;
  3. using EVCB_OCPP.WSServer.Service.WsService;
  4. using Microsoft.EntityFrameworkCore;
  5. using Microsoft.Extensions.Logging;
  6. using Quartz;
  7. using System;
  8. using System.Collections.Generic;
  9. using System.Diagnostics;
  10. using System.Linq;
  11. using System.Text;
  12. using System.Threading.Tasks;
  13. namespace EVCB_OCPP.WSServer.Jobs;
  14. [DisallowConcurrentExecution]
  15. public class HeartBeatCheckJob : IJob
  16. {
  17. public HeartBeatCheckJob(
  18. ProtalServer protalServer,
  19. IDbContextFactory<MainDBContext> maindbContextFactory,
  20. IMainDbService mainDbService,
  21. ILogger<HeartBeatCheckJob> logger)
  22. {
  23. this.protalServer = protalServer;
  24. this.maindbContextFactory = maindbContextFactory;
  25. this.mainDbService = mainDbService;
  26. this.logger = logger;
  27. }
  28. private readonly ProtalServer protalServer;
  29. private readonly IDbContextFactory<MainDBContext> maindbContextFactory;
  30. private readonly IMainDbService mainDbService;
  31. private readonly ILogger<HeartBeatCheckJob> logger;
  32. public async Task Execute(IJobExecutionContext context)
  33. {
  34. //logger.LogDebug("{0} Started", nameof(HeartBeatCheckJob));
  35. try
  36. {
  37. Stopwatch watch = new Stopwatch();
  38. Dictionary<string, WsClientData> _copyClientDic = protalServer.GetClientDic();
  39. var cdt = DateTime.UtcNow;
  40. var clients = _copyClientDic.Where(x => x.Value.LastActiveTime > cdt.AddSeconds(-120)).Select(x => x.Value).ToList();
  41. watch.Start();
  42. //var datas = new List<Machine>();
  43. //foreach (var session in clients)
  44. //{
  45. // var machine = new Machine() { Id = session.MachineId, HeartbeatUpdatedOn = cdt, ConnectionType = session.UriScheme.Equals("wss") ? 2 : 1 };
  46. // datas.Add(machine);
  47. //}
  48. //await mainDbService.UpdateHeartBeats(datas);
  49. var toUpdateMachineIds = clients.Select(x => x.MachineId).ToList();
  50. await mainDbService.UpdateHeartBeats(toUpdateMachineIds);
  51. watch.Stop();
  52. if (watch.ElapsedMilliseconds / 1000 > 5)
  53. {
  54. logger.LogCritical("Update HeartBeatCheckTrigger cost " + watch.ElapsedMilliseconds / 1000 + " seconds.");
  55. }
  56. }
  57. catch (Exception ex)
  58. {
  59. Console.WriteLine("***********************************************************");
  60. logger.LogError(string.Format("HeartBeatCheckTrigger Ex:{0}", ex.ToString()));
  61. }
  62. }
  63. }