HeartBeatCheckJob.cs 2.4 KB

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