AsyncBehavior.cs 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. using DbCommon.BusinessCore.BaseCore;
  2. using DbCommon.Enties.DbModels;
  3. using Newtonsoft.Json;
  4. using ProjectManagementSystem.Common.Models.Crms;
  5. using ProjectManagementSystem.Common.Extenions;
  6. using ProjectManagementSystem.Common.Logger;
  7. using ProjectManagementSystem.Common.Service;
  8. using System;
  9. using System.Collections.Concurrent;
  10. using System.Collections.Generic;
  11. using System.Linq;
  12. using System.Text;
  13. using System.Threading;
  14. using System.Threading.Tasks;
  15. namespace ProjectManagementSystem.Common.Core
  16. {
  17. public class AsyncBehavior
  18. {
  19. private static ConcurrentDictionary<string, string> tempLog = new ConcurrentDictionary<string, string>();
  20. private AsyncBehaviorManager asyncBehaviorManager = new AsyncBehaviorManager();
  21. public Guid Id { get; set; }
  22. public int Behavior { get; set; }
  23. public int Interval { get; set; } = 1000;
  24. public string TaskID { get; set; }
  25. public int AgvId { get; set; }
  26. public int MaxStepId { get; set; }
  27. public bool FirstStart { get; set; }
  28. public void Init()
  29. {
  30. Id = Guid.NewGuid();
  31. var mode = new AsyncBehaviorModel();
  32. mode.Id = Id;
  33. mode.TaskID = TaskID;
  34. mode.AgvId = AgvId;
  35. mode.Behavior = Behavior;
  36. mode.Interval = Interval;
  37. mode.MaxStepId = MaxStepId;
  38. mode.FirstStart = FirstStart;
  39. mode.AssemblyString = this.GetType().Assembly.GetName().Name;
  40. mode.FullClassName = this.GetType().FullName;
  41. asyncBehaviorManager.Insert(mode);
  42. }
  43. public void Start()
  44. {
  45. Task.Factory.StartNew(BehaviorProc);
  46. }
  47. public void BehaviorProc()
  48. {
  49. FirstStart = true;
  50. CLog.Instance.GetAgvLog(AgvId).WriteInfo($"【异步】 {TaskID} {Behavior} 启动 检测间隔{Interval}ms 最大步骤{MaxStepId}");
  51. while (true)
  52. {
  53. try
  54. {
  55. var taskData = Crms.PmsApi.GetTaskData(TaskID);
  56. if (taskData == null)
  57. {
  58. var taskList = Crms.PmsApi.GetTaskList();
  59. if (taskList != null
  60. && taskList.FirstOrDefault(d => d.TaskID == TaskID) == null)
  61. {
  62. CLog.Instance.GetAgvLog(AgvId).WriteInfo($"【异步】 {TaskID} {Behavior} 未找到当前任务信息,异步行为码完成");
  63. break;
  64. }
  65. CLog.Instance.GetAgvLog(AgvId).WriteInfo($"【异步】 {TaskID} {Behavior} 获取当前任务信息失败,再次尝试...");
  66. Thread.Sleep(Interval);
  67. continue;
  68. }
  69. var stepInfo = taskData.GetCurrentStepInfo();
  70. if (FirstStart
  71. && FirstOperator(taskData, stepInfo))
  72. {
  73. FirstStart = false;
  74. }
  75. if (taskData.CurrentStepID > MaxStepId)
  76. {
  77. Log(taskData, stepInfo, $"当前任务步骤为{taskData.CurrentStepID} 大于 {MaxStepId},行为码完成(跳出)");
  78. break;
  79. }
  80. if (!FirstStart)
  81. {
  82. if (CustomOperator(taskData, stepInfo))
  83. {
  84. Log(taskData, stepInfo, "正常完成");
  85. break;
  86. }
  87. }
  88. }
  89. catch (Exception ex)
  90. {
  91. CLog.Instance.TaskLog.WriteException("AsyncBehavior", ex);
  92. Thread.Sleep(5000);
  93. }
  94. Thread.Sleep(Interval);
  95. }
  96. RemoveTempLog(TaskID);
  97. asyncBehaviorManager.Delete(Id);
  98. }
  99. public virtual bool FirstOperator(TaskData taskData, StepData stepInfo)
  100. {
  101. return true;
  102. }
  103. public virtual bool CustomOperator(TaskData taskData, StepData stepInfo)
  104. {
  105. return true;
  106. }
  107. public static void RemoveTempLog(string taskId)
  108. {
  109. if (string.IsNullOrEmpty(taskId)) return;
  110. tempLog.TryRemove(taskId, out string _);
  111. }
  112. public static string GetTempLog(string taskId)
  113. {
  114. if (string.IsNullOrEmpty(taskId)) return null;
  115. return tempLog.TryGetValue(taskId, out string log) ? log : null;
  116. }
  117. public static void Log(TaskData taskData, StepData stepData, string log)
  118. {
  119. bool result = tempLog.TryGetValue(taskData.TaskID, out string templog) ? templog == log : false;
  120. if (result) return;
  121. tempLog.AddOrUpdate(taskData.TaskID, log, (key, vaule) => log);
  122. string strLog = $"【异步】 {taskData.TaskID} Step{taskData.CurrentStepID} {stepData.PmsBehavior} {stepData.AgvBehavior} {taskData.Carrier}# {stepData.WareHouseID} {log}";
  123. CLog.Instance.GetAgvLog(taskData.Carrier).WriteInfo(strLog);
  124. }
  125. }
  126. }