TskScheduler.cs 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339
  1. using DevExpress.Xpo;
  2. using Ips.Sps.Tsks;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.Collections.Concurrent;
  6. using System.Linq;
  7. using System.Text;
  8. using System.Threading.Tasks;
  9. using Ips.Library.Basic;
  10. using Ips.Sps.Scheduling.Entities;
  11. using Ips.Library.Entity;
  12. using Ips.Sps.Ants;
  13. using Ips.Sps.Sats;
  14. using System.Configuration;
  15. using Ips.Sps.TskResults.Stses;
  16. using Ips.Library.LocLib;
  17. namespace Ips.Sps.Scheduling
  18. {
  19. public class TskScheduler
  20. {
  21. public static readonly TskScheduler Default = new TskScheduler();
  22. public TskScheduler()
  23. {
  24. _tskManager = TskManager.Default;
  25. }
  26. TskManager _tskManager;
  27. private static readonly object locker = new object();
  28. List<RunTsk> _runTskList = new List<RunTsk>();
  29. ConcurrentDictionary<int, TskHandler> _runHanderList = new ConcurrentDictionary<int, TskHandler>();
  30. public void Start(int tskId)
  31. {
  32. if (_runTskList.Any(m => m.TskId == tskId))
  33. {
  34. throw new Exception("任务已在运行中!");
  35. }
  36. Session _session = new Session();
  37. var tsk = _session.GetObjectByKey<Tsk>(tskId);
  38. if (tsk == null)
  39. throw new Exception("任务不存在!");
  40. if (tsk.AdCardList.ToList().IsNullOrEmpty())
  41. throw new Exception("任务采集卡不存在!");
  42. if (tsk.SignalList.ToList().IsNullOrEmpty() && tsk.RefSignalList.ToList().IsNullOrEmpty())
  43. throw new Exception("任务信号不存在!");
  44. var runTsk = BuildRunTsk(tsk, _session);
  45. if (runTsk != null)
  46. {
  47. QueueTsk(runTsk);
  48. ExecuteTsk(runTsk);
  49. }
  50. }
  51. public void Stop(int tskId)
  52. {
  53. if (_runHanderList.ContainsKey(tskId))
  54. {
  55. _runHanderList[tskId].Stop();
  56. _tskManager.UpdateTskState(tskId, TskState.Stopping);
  57. IpsLogger.Info($"任务【{_runHanderList[tskId]._tsk.TskName}】停止中...");
  58. }
  59. else
  60. {
  61. var tskContext = _runTskList.FirstOrDefault(m => m.TskId == tskId);
  62. if (tskContext == null) return;
  63. TskStop(tskContext);
  64. }
  65. }
  66. public void StopAll(bool wait = false)
  67. {
  68. while (_runTskList.Any())
  69. {
  70. Stop(_runTskList[0].TskId);
  71. }
  72. if (wait)
  73. {
  74. while (_runTskList.Any())
  75. {
  76. Task.Delay(500).Wait();
  77. }
  78. }
  79. }
  80. public List<RunTsk> GetRunTskList()
  81. {
  82. return _runTskList;
  83. }
  84. protected virtual RunTsk BuildRunTsk(Tsk tsk, Session _session)
  85. {
  86. RunTsk _runTsk = new RunTsk();
  87. _runTsk.TskId = tsk.Oid;
  88. _runTsk.TskName = tsk.Name;
  89. _runTsk.WorkTime = DateTime.Now;
  90. _runTsk.DfLoc = tsk.DfLoc;
  91. _runTsk.IsHistory = tsk.IsHistory;
  92. _runTsk.TskType = tsk.Strategy.TskType;
  93. _runTsk.SigType = tsk.Strategy.SigType;
  94. _runTsk.AdMode = tsk.Strategy.AdMode;
  95. if (tsk.IsHistory)
  96. {
  97. //_runTsk.FileFindType = tsk.Strategy.AdMode == AdMode.DDCKeep ? SigFileFindType.ByFS : SigFileFindType.ByDB;
  98. _runTsk.FileFindType = SigFileFindType.ByFS;
  99. }
  100. _runTsk.StartTime = tsk.StartTime;
  101. _runTsk.StopTime = tsk.EndTime;
  102. _runTsk.SigTime = DateTime.MinValue;
  103. var runCard = _runTsk.AdCard = new RunAdCard();
  104. var adCard = tsk.AdCardList.First();
  105. runCard.CardId = adCard.Oid;
  106. runCard.CardName = adCard.Name;
  107. runCard.CardCode = adCard.Code ?? string.Empty;
  108. runCard.CardType = adCard.CardType;
  109. runCard.TriggerMode = adCard.TriggerMode;
  110. runCard.ClockType = adCard.ClockerType;
  111. runCard.ClockFreq = adCard.ClockFreq.E6();
  112. runCard.DdcFreq = adCard.DdcFreq.E6();
  113. if (tsk.Strategy.AdMode != AdMode.ADC)
  114. {
  115. runCard.Mutil = adCard.Mutil;
  116. }
  117. else
  118. {
  119. runCard.Mutil = 1;
  120. }
  121. runCard.StorePath = adCard.StorePath;
  122. var antIds = adCard.Channels.Select(m => m.AntId).Distinct();
  123. var antList = _session.Query<Ant>().Where(m => antIds.Contains(m.Oid)).ToList();
  124. var satIds = adCard.Channels.SelectMany(m => m.GetSatIds()).Distinct();
  125. var satList = _session.Query<Sat>().Where(m => satIds.Contains(m.Oid)).ToList();
  126. foreach (var adch in adCard.Channels)
  127. {
  128. var runCh = new RunAdCh();
  129. runCh.ChId = adch.Oid;
  130. runCh.ChNum = adch.ChNum;
  131. runCh.FixCenter = adch.FixCenter;
  132. runCh.CenterFreq = adch.CenterFreq.E6l();
  133. runCh.FrqAddr = adch.FrqAddr;
  134. runCh.FrqTurn = adch.FrqTurn.E6l();
  135. runCh.AdcCode = adCard.Code;
  136. runCh.AntId = adch.AntId;
  137. var ant = antList.FirstOrDefault(m => m.Oid == adch.AntId);
  138. if (ant != null)
  139. {
  140. runCh.AntName = ant.Name;
  141. runCh.AntCode = ant.Code;
  142. runCh.AntLon = ant.Lon;
  143. runCh.AntLat = ant.Lat;
  144. runCh.AntAlt = ant.Alt;
  145. }
  146. if (adch.SatIds.IsNotNullOrWhitespace())
  147. {
  148. var chSatIds = adch.GetSatIds();
  149. chSatIds.ForEach(satid =>
  150. {
  151. var sat = satList.FirstOrDefault(m => m.Oid == satid);
  152. if (sat != null)
  153. {
  154. var runSat = new RunSat();
  155. runSat.SatId = sat.Oid;
  156. runSat.SatNum = sat.SatNum;
  157. runSat.SatName = sat.Name;
  158. runSat.SatType = sat.SatType;
  159. runSat.SatCode = sat.SatNum.ToString();
  160. runSat.SatTurn = sat.SatTurn.E6l();
  161. runCh.Sats.Add(runSat);
  162. }
  163. });
  164. }
  165. runCard.Channels.Add(runCh);
  166. }
  167. var tarSigList = tsk.SignalList.OrderBy(m => m.SigFreq).ThenBy(m => m.BandWidth).ToList();
  168. var refSigList = tsk.RefSignalList.OrderBy(m => m.SigFreq).ThenBy(m => m.BandWidth).ToList();
  169. List<int> mainSatIds = new List<int>();
  170. foreach (var tskSig in tarSigList.Concat(refSigList))
  171. {
  172. RunSig sig = new RunSig();
  173. sig.SigId = tskSig.Oid;
  174. sig.SigCategory = tskSig.SigCategory;
  175. sig.SigType = tskSig.SigType;
  176. sig.SigFreq = tskSig.SigFreq.E6l();
  177. sig.FreqStart = tskSig.FreqStart.E6l();
  178. sig.FreqEnd = tskSig.FreqEnd.E6l();
  179. sig.FreqStep = tskSig.FreqStep.E3();
  180. sig.BandWidth = tskSig.BandWidth.E3();
  181. sig.SigLen = tskSig.SigLen;
  182. sig.MainSatId = tskSig.MainSatId ?? 0;
  183. mainSatIds.Add(sig.MainSatId);
  184. if (tskSig.AdjaSatIds.IsNotNullOrWhitespace())
  185. {
  186. sig.AdjaSatIds = tskSig.AdjaSatIds.Split(',').Select(m => int.Parse(m)).ToList();
  187. }
  188. else
  189. {
  190. sig.AdjaSatIds = adCard.Channels
  191. .Where(m => !m.GetSatIds().Any(m => m == sig.MainSatId))
  192. .SelectMany(m => m.GetSatIds())
  193. .ToList();
  194. }
  195. sig.HasRange = tskSig.HasRange;
  196. sig.SigLon = tskSig.HasRange ? tskSig.SigLon : 0;
  197. sig.SigLat = tskSig.HasRange ? tskSig.SigLat : 0;
  198. sig.SigAlt = tskSig.SigAlt;
  199. sig.LonRange = tskSig.HasRange ? tskSig.LonRange : 360;
  200. sig.LatRange = tskSig.HasRange ? tskSig.LatRange : 180;
  201. sig.EmtId = tskSig.EmtId ?? 0;
  202. if (sig.EmtId > 0)
  203. {
  204. var emt = _session.GetObjectByKey<Emts.Emt>(sig.EmtId);
  205. if (emt != null)
  206. {
  207. sig.SigEmtCode = emt.Code;
  208. sig.SigEmtName = emt.Name;
  209. sig.SigEmtType = emt.EmtType;
  210. sig.SigEmtSpeed = emt.Speed;
  211. if (emt.HasSample)
  212. {
  213. var samples = emt.SigSamples
  214. .Where(m => m.Enable && m.SigFreq == tskSig.SigFreq && m.BandWidth == tskSig.BandWidth)
  215. .ToList();
  216. foreach (var smpl in samples)
  217. {
  218. RunSigSample runSmpl = new RunSigSample();
  219. runSmpl.SampleId = smpl.Oid;
  220. runSmpl.SigFreq = smpl.SigFreq.E6l();
  221. runSmpl.BandWidth = smpl.BandWidth.E3();
  222. runSmpl.Fs = smpl.Fs;
  223. runSmpl.StartSec = smpl.StartSec;
  224. runSmpl.EndSec = smpl.EndSec;
  225. runSmpl.SampleFile = smpl.SampleFile;
  226. sig.SigSamples.Add(runSmpl);
  227. }
  228. }
  229. if (emt.EmtType == EmtType.FixSation && !sig.HasRange)
  230. {
  231. sig.SigLon = emt.Lon;
  232. sig.SigLat = emt.Lat;
  233. sig.LonRange = 6;
  234. sig.LatRange = 6;
  235. }
  236. sig.SigAlt = sig.HasRange ? sig.SigAlt : emt.Alt;
  237. sig.HasSample = sig.SigSamples.IsNotNullOrEmpty();
  238. }
  239. }
  240. sig.Fs = SigCalcUtil.CalcFs(runCard.ClockFreq, sig.BandWidth, runCard.Mutil);
  241. if (sig.SigCategory != SignalCategory.RefSig)
  242. {
  243. _runTsk.TarSigList.Add(sig);
  244. }
  245. else
  246. {
  247. _runTsk.RefSigList.Add(sig);
  248. }
  249. }
  250. var dxSigList = tsk.DxSignalList.OrderBy(m => m.SigFreq).ThenBy(m => m.BandWidth).ToList();
  251. mainSatIds= mainSatIds.Distinct().ToList();
  252. foreach (var dxSig in dxSigList)
  253. {
  254. DxSig dx = new DxSig();
  255. dx.DxSigId = dxSig.Oid;
  256. dx.SigType = dxSig.SigType;
  257. dx.SigFreq = dxSig.SigFreq.E6l();
  258. dx.BandWidth = dxSig.BandWidth.E3();
  259. if (dxSig.AdjaSatIds.IsNotNullOrWhitespace())
  260. {
  261. dx.AdjaSatIds = dxSig.AdjaSatIds.Split(',').Select(m => int.Parse(m)).ToList();
  262. }
  263. else
  264. {
  265. dx.AdjaSatIds = adCard.Channels
  266. .Where(m => !m.GetSatIds().Any(m => mainSatIds.Contains(m)))
  267. .SelectMany(m => m.GetSatIds())
  268. .ToList();
  269. }
  270. _runTsk.DxSigList.Add(dx);
  271. }
  272. return _runTsk;
  273. }
  274. protected virtual void QueueTsk(RunTsk runTsk)
  275. {
  276. _runTskList.Add(runTsk);
  277. _tskManager.UpdateTskState(runTsk.TskId, TskState.Wait);
  278. IpsLogger.Info($"任务【{runTsk.TskName}】已添加到执行队列...");
  279. }
  280. protected virtual void ExecuteTsk(RunTsk runTsk)
  281. {
  282. if (_runHanderList.Any()) return;
  283. TskHandler tskHandler = new TskHandler(runTsk);
  284. tskHandler.Start().ContinueWith(TskHandleCompleted, tskHandler);
  285. _runHanderList.TryAdd(runTsk.TskId, tskHandler);
  286. _tskManager.UpdateTskState(runTsk.TskId, TskState.Running);
  287. IpsLogger.Info($"任务【{runTsk.TskName}】开始执行...");
  288. }
  289. protected virtual void TskHandleCompleted(Task tsk, object state)
  290. {
  291. var handler = state as TskHandler;
  292. if (handler == null) return;
  293. _runHanderList.Remove(handler._tsk.TskId, out _);
  294. if (handler._tsk.SigTime >= handler._tsk.StopTime || handler.IsCancelled)
  295. {
  296. TskStop(handler._tsk);
  297. }
  298. else
  299. {
  300. _tskManager.UpdateTskState(handler._tsk.TskId, TskState.Wait);
  301. }
  302. lock (locker)
  303. {
  304. //按ID排序,查找下一个任务上下文
  305. var nextContext = _runTskList.Where(m => m.TskId < handler._tsk.TskId)
  306. .OrderByDescending(m => m.TskId)
  307. .FirstOrDefault();
  308. if (nextContext == null)
  309. nextContext = _runTskList.OrderByDescending(m => m.TskId).FirstOrDefault();
  310. if (nextContext != null)
  311. ExecuteTsk(nextContext);
  312. }
  313. }
  314. protected virtual void TskStop(RunTsk runTsk)
  315. {
  316. _runTskList.Remove(runTsk);
  317. _tskManager.UpdateTskState(runTsk.TskId, TskState.Stop);
  318. IpsLogger.Info($"任务【{runTsk.TskName}】已停止");
  319. }
  320. }
  321. }