123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119 |
- using System;
- using System.Collections.Concurrent;
- using System.Collections.Generic;
- using System.Configuration;
- using System.Data.Entity;
- using System.Linq;
- using System.Threading;
- using System.Threading.Tasks;
- using XdCxRhDW.Dto;
- using XdCxRhDW.Entity;
- using XdCxRhDW.Framework;
- using XdCxRhDW.Repostory;
- namespace XdCxRhDW.App
- {
- /// <summary>
- /// 两星一地定位取参考服务
- /// </summary>
- public class X2D1PosRefService
- {
- public static X2D1PosRefService Instance { get; private set; } = new X2D1PosRefService();
- readonly List<X2D1PosHandle> handles = new List<X2D1PosHandle>();
- public double TakeRefTime;
- public X2D1PosRefService()
- {
- TakeRefTime = AppConfigHelper.Get("TakeRefTime", 10);
- StartMonitor();
- }
- public void StartMonitor()
- {
- Task.Run(async () =>
- {
- while (true)
- {
- if (handles.Count == 0)
- {
- Thread.Sleep(5000);
- }
- try
- {
- lock (this)
- {
- List<X2D1PosHandle> deletes = new List<X2D1PosHandle>();
- using (RHDWContext db = new RHDWContext())
- {
- for (int i = 0; i < handles.Count; i++)
- {
- var handle = handles[i];
- var runTask = db.TaskInfos.FirstOrDefault(p => p.ID == handle.TaskId && p.TaskState == EnumTaskState.Running);
- if (runTask == null)
- {
- handle.Stop();
- deletes.Add(handle);
- }
- }
- }
- //删除未运行的任务
- handles.RemoveAll(r => deletes.Any(d => d.TaskId == r.TaskId));
- }
- Thread.Sleep(5000);
- }
- catch (Exception ex)
- {
- await LogHelper.Error($"【监视取参考任务运行状态异常,{ex.Message}",ex);
- }
- }
- });
- }
- public void AddPosDto(List<X2D1NoXlNoParlPosDto> dtos)
- {
- try
- {
- var dto = dtos.First();
- lock (this)
- {
- var firstDto = handles.FirstOrDefault(m => m.TaskId == dto.TaskID);
- if (firstDto == null)
- {
- firstDto = new X2D1PosHandle(dto.TaskID.Value, TakeRefTime);
- handles.Add(firstDto);
- }
- firstDto.Append(dtos);
- }
- }
- catch (Exception ex)
- {
- LogHelper.Error($"【任务{dtos.First().TaskID}】添加取参考信号流程异常,{ex.Message}",ex).GetAwaiter();
- }
- }
- public void Stop(int taskID)
- {
- try
- {
- lock (this)
- {
- var firstDto = handles.FirstOrDefault(m => m.TaskId == taskID);
- if (firstDto != null)
- {
- firstDto.Stop();
- handles.Remove(firstDto);
- }
- }
- }
- catch (Exception ex)
- {
- LogHelper.Error($"停止【任务{taskID}】取参考信号流程异常,{ex.Message}",ex).GetAwaiter();
- }
- }
- }
- }
|