X2D1PosRefService.cs 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  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(async () =>
  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. await LogHelper.Error($"【监视取参考任务运行状态异常,{ex.Message}",ex);
  64. }
  65. }
  66. });
  67. }
  68. public void AddPosDto(List<X2D1NoXlNoParlPosDto> dtos)
  69. {
  70. try
  71. {
  72. var dto = dtos.First();
  73. lock (this)
  74. {
  75. var firstDto = handles.FirstOrDefault(m => m.TaskId == dto.TaskID);
  76. if (firstDto == null)
  77. {
  78. firstDto = new X2D1PosHandle(dto.TaskID.Value, TakeRefTime);
  79. handles.Add(firstDto);
  80. }
  81. firstDto.Append(dtos);
  82. }
  83. }
  84. catch (Exception ex)
  85. {
  86. LogHelper.Error($"【任务{dtos.First().TaskID}】添加取参考信号流程异常,{ex.Message}",ex).GetAwaiter();
  87. }
  88. }
  89. public void Stop(int taskID)
  90. {
  91. try
  92. {
  93. lock (this)
  94. {
  95. var firstDto = handles.FirstOrDefault(m => m.TaskId == taskID);
  96. if (firstDto != null)
  97. {
  98. firstDto.Stop();
  99. handles.Remove(firstDto);
  100. }
  101. }
  102. }
  103. catch (Exception ex)
  104. {
  105. LogHelper.Error($"停止【任务{taskID}】取参考信号流程异常,{ex.Message}",ex).GetAwaiter();
  106. }
  107. }
  108. }
  109. }