X2D1PosRefService.cs 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. using System;
  2. using System.Collections.Concurrent;
  3. using System.Collections.Generic;
  4. using System.Configuration;
  5. using System.Data.Entity;
  6. using System.Linq;
  7. using System.Threading;
  8. using System.Threading.Tasks;
  9. using XdCxRhDW.Dto;
  10. using XdCxRhDW.Entity;
  11. using XdCxRhDW.Framework;
  12. using XdCxRhDW.Repostory;
  13. namespace XdCxRhDW.App
  14. {
  15. /// <summary>
  16. /// 两星一地定位取参考服务
  17. /// </summary>
  18. public class X2D1PosRefService
  19. {
  20. public static X2D1PosRefService Instance { get; private set; } = new X2D1PosRefService();
  21. readonly List<X2D1PosHandle> handles = new List<X2D1PosHandle>();
  22. public double TakeRefTime;
  23. public X2D1PosRefService()
  24. {
  25. TakeRefTime = AppConfigHelper.Get("TakeRefTime", 10);
  26. StartMonitor();
  27. }
  28. public void StartMonitor()
  29. {
  30. Task.Run(() =>
  31. {
  32. while (true)
  33. {
  34. if (handles.Count == 0)
  35. {
  36. Thread.Sleep(5000);
  37. }
  38. try
  39. {
  40. lock (this)
  41. {
  42. List<X2D1PosHandle> deletes = new List<X2D1PosHandle>();
  43. using (RHDWContext db = new RHDWContext())
  44. {
  45. for (int i = 0; i < handles.Count; i++)
  46. {
  47. var handle = handles[i];
  48. var runTask = db.TaskInfos.FirstOrDefault(p => p.ID == handle.TaskId && p.TaskState == EnumTaskState.Running);
  49. if (runTask == null)
  50. {
  51. handle.Stop();
  52. deletes.Add(handle);
  53. }
  54. }
  55. }
  56. //删除未运行的任务
  57. handles.RemoveAll(r => deletes.Any(d => d.TaskId == r.TaskId));
  58. }
  59. Thread.Sleep(5000);
  60. }
  61. catch (Exception ex)
  62. {
  63. Serilog.Log.Error(ex, $"【监视取参考任务运行状态异常,{ex.Message}");
  64. }
  65. }
  66. });
  67. }
  68. public void AddPosDto(X2D1NoXlNoParlPosDto dto)
  69. {
  70. try
  71. {
  72. lock (this)
  73. {
  74. var firstDto = handles.FirstOrDefault(m => m.TaskId == dto.TaskID);
  75. if (firstDto == null)
  76. {
  77. firstDto = new X2D1PosHandle(dto.TaskID.Value, TakeRefTime);
  78. handles.Add(firstDto);
  79. }
  80. firstDto.Append(dto);
  81. }
  82. }
  83. catch (Exception ex)
  84. {
  85. Serilog.Log.Error(ex, $"【任务{dto.TaskID}】添加取参考信号流程异常,{ex.Message}");
  86. }
  87. }
  88. public void Stop(int taskID)
  89. {
  90. try
  91. {
  92. lock (this)
  93. {
  94. var firstDto = handles.FirstOrDefault(m => m.TaskId == taskID);
  95. if (firstDto != null)
  96. {
  97. firstDto.Stop();
  98. handles.Remove(firstDto);
  99. }
  100. }
  101. }
  102. catch (Exception ex)
  103. {
  104. Serilog.Log.Error(ex, $"停止【任务{taskID}】取参考信号流程异常,{ex.Message}");
  105. }
  106. }
  107. }
  108. }