HeartBeatCheckJob.cs 3.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. using EVCB_OCPP.Domain;
  2. using EVCB_OCPP.Domain.Models.Database;
  3. using Microsoft.EntityFrameworkCore;
  4. using Microsoft.Extensions.Logging;
  5. using OCPPServer.Protocol;
  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. ILogger<HeartBeatCheckJob> logger)
  21. {
  22. this.protalServer = protalServer;
  23. this.maindbContextFactory = maindbContextFactory;
  24. this.logger = logger;
  25. }
  26. private readonly ProtalServer protalServer;
  27. private readonly IDbContextFactory<MainDBContext> maindbContextFactory;
  28. private readonly ILogger<HeartBeatCheckJob> logger;
  29. public async Task Execute(IJobExecutionContext context)
  30. {
  31. logger.LogDebug("{0} Started", nameof(HeartBeatCheckJob));
  32. try
  33. {
  34. Stopwatch watch = new Stopwatch();
  35. Dictionary<string, ClientData> _copyClientDic = protalServer.ClientDic;
  36. var cdt = DateTime.UtcNow;
  37. var clients = _copyClientDic.Where(x => x.Value.LastActiveTime > cdt.AddSeconds(-120)).Select(x => x.Value).ToList();
  38. watch.Start();
  39. using (var db = await maindbContextFactory.CreateDbContextAsync())
  40. using (var transaction = await db.Database.BeginTransactionAsync())
  41. {
  42. try
  43. {
  44. foreach (var session in clients)
  45. {
  46. var machine = new Machine() { Id = session.MachineId };
  47. if (machine != null)
  48. {
  49. //db.Configuration.AutoDetectChangesEnabled = false;
  50. //db.Configuration.ValidateOnSaveEnabled = false;
  51. db.Machine.Attach(machine);
  52. machine.HeartbeatUpdatedOn = DateTime.UtcNow;
  53. machine.ConnectionType = session.UriScheme.Equals("wss") ? 2 : 1;
  54. db.Entry(machine).Property(x => x.HeartbeatUpdatedOn).IsModified = true;
  55. db.Entry(machine).Property(x => x.ConnectionType).IsModified = true;
  56. //await db.SaveChangesAsync();
  57. }
  58. }
  59. await db.SaveChangesAsync();
  60. await transaction.CommitAsync();
  61. db.ChangeTracker.Clear();
  62. }
  63. catch (Exception ex)
  64. {
  65. logger.LogCritical(ex, "HeartBeatCheckTrigger update fail, roll back");
  66. transaction.Rollback();
  67. }
  68. }
  69. watch.Stop();
  70. if (watch.ElapsedMilliseconds / 1000 > 5)
  71. {
  72. logger.LogCritical("Update HeartBeatCheckTrigger cost " + watch.ElapsedMilliseconds / 1000 + " seconds.");
  73. }
  74. }
  75. catch (Exception ex)
  76. {
  77. Console.WriteLine("***********************************************************");
  78. logger.LogError(string.Format("HeartBeatCheckTrigger Ex:{0}", ex.ToString()));
  79. }
  80. }
  81. }