X2D1PosRefService.cs 3.8 KB

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