HeartBeatCheckJob.cs 4.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  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. {
  15. [DisallowConcurrentExecution]
  16. public class HeartBeatCheckJob : IJob
  17. {
  18. public HeartBeatCheckJob(
  19. ProtalServer protalServer,
  20. IDbContextFactory<MainDBContext> maindbContextFactory,
  21. ILogger<HeartBeatCheckJob> logger)
  22. {
  23. this.protalServer = protalServer;
  24. this.maindbContextFactory = maindbContextFactory;
  25. this.logger = logger;
  26. }
  27. private readonly ProtalServer protalServer;
  28. private readonly IDbContextFactory<MainDBContext> maindbContextFactory;
  29. private readonly ILogger<HeartBeatCheckJob> logger;
  30. public async Task Execute(IJobExecutionContext context)
  31. {
  32. logger.LogDebug("{0} Started", nameof(HeartBeatCheckJob));
  33. try
  34. {
  35. Stopwatch watch = new Stopwatch();
  36. Dictionary<string, ClientData> _copyClientDic = protalServer.ClientDic;
  37. var cdt = DateTime.UtcNow;
  38. var clients = _copyClientDic.Where(x => x.Value.LastActiveTime > cdt.AddSeconds(-120)).Select(x => x.Value).ToList();
  39. watch.Start();
  40. await Parallel.ForEachAsync(clients, async (session, token ) => {
  41. using (var db = await maindbContextFactory.CreateDbContextAsync())
  42. {
  43. var machine = new Machine() { Id = session.MachineId };
  44. if (machine != null)
  45. {
  46. //db.Configuration.AutoDetectChangesEnabled = false;
  47. //db.Configuration.ValidateOnSaveEnabled = false;
  48. db.Machine.Attach(machine);
  49. machine.HeartbeatUpdatedOn = DateTime.UtcNow;
  50. machine.ConnectionType = session.UriScheme.Equals("wss") ? 2 : 1;
  51. db.Entry(machine).Property(x => x.HeartbeatUpdatedOn).IsModified = true;
  52. db.Entry(machine).Property(x => x.ConnectionType).IsModified = true;
  53. await db.SaveChangesAsync(token);
  54. }
  55. }
  56. });
  57. //foreach (var session in clients)
  58. //{
  59. // using (var db = await maindbContextFactory.CreateDbContextAsync())
  60. // {
  61. // var machine = new Machine() { Id = session.MachineId };
  62. // if (machine != null)
  63. // {
  64. // //db.Configuration.AutoDetectChangesEnabled = false;
  65. // //db.Configuration.ValidateOnSaveEnabled = false;
  66. // db.Machine.Attach(machine);
  67. // machine.HeartbeatUpdatedOn = DateTime.UtcNow;
  68. // machine.ConnectionType = session.UriScheme.Equals("wss") ? 2 : 1;
  69. // db.Entry(machine).Property(x => x.HeartbeatUpdatedOn).IsModified = true;
  70. // db.Entry(machine).Property(x => x.ConnectionType).IsModified = true;
  71. // await db.SaveChangesAsync();
  72. // }
  73. // }
  74. //}
  75. watch.Stop();
  76. if (watch.ElapsedMilliseconds / 1000 > 5)
  77. {
  78. logger.LogCritical("Update HeartBeatCheckTrigger cost " + watch.ElapsedMilliseconds / 1000 + " seconds.");
  79. }
  80. }
  81. catch (Exception ex)
  82. {
  83. Console.WriteLine("***********************************************************");
  84. logger.LogError(string.Format("HeartBeatCheckTrigger Ex:{0}", ex.ToString()));
  85. }
  86. }
  87. }
  88. }