CtrlSvrs.cs 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. using DevExpress.Utils.Html;
  2. using DevExpress.XtraEditors;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.ComponentModel;
  6. using System.Data;
  7. using System.Data.Entity;
  8. using System.Drawing;
  9. using System.Linq;
  10. using System.Text;
  11. using System.Threading.Tasks;
  12. using System.Windows.Controls;
  13. using System.Windows.Documents;
  14. using System.Windows.Forms;
  15. using XdCxRhDW.App.Controllers;
  16. using XdCxRhDW.App.EditForms;
  17. using XdCxRhDW.App.Model;
  18. using XdCxRhDW.Dto;
  19. namespace XdCxRhDW.App.UserControl
  20. {
  21. public partial class CtrlSvrs : DevExpress.XtraEditors.XtraUserControl
  22. {
  23. List<ModelSvrs> list = new List<ModelSvrs>();
  24. public CtrlSvrs()
  25. {
  26. InitializeComponent();
  27. gridSvrs.UseDefault(list).UseGroup().UseRowNumber();
  28. gridSvrs.UseEdit();
  29. var linkEdit = new DevExpress.XtraEditors.Repository.RepositoryItemHyperLinkEdit();
  30. this.gridSvrs.RepositoryItems.Add(linkEdit);
  31. gridView1.Columns[nameof(ModelSvrs.SwaggerAddr)].ColumnEdit = linkEdit;
  32. gridView1.Columns[nameof(ModelSvrs.SwaggerAddr)].OptionsColumn.AllowEdit = true;
  33. TaskSvr.EventTaskSvr += TaskSvr_EventTaskSvr;
  34. }
  35. private ItemSvrEventArgs TaskSvr_EventTaskSvr()
  36. {
  37. ItemSvrEventArgs itemSvr = new ItemSvrEventArgs();
  38. itemSvr.code = -1;
  39. itemSvr.msg = "没有服务";
  40. if (list.Count == 0)
  41. {
  42. return itemSvr;
  43. }
  44. itemSvr.code = 1;
  45. itemSvr.msg = string.Empty;
  46. itemSvr.modelSvrs = list.OrderByDescending(s => s.ReportTime).First();
  47. return itemSvr;
  48. }
  49. private async void CtrlSat_Load(object sender, EventArgs e)
  50. {
  51. Messenger.Defalut.Sub<SvrStateReportDto>("服务状态改变", dto =>
  52. {
  53. try
  54. {
  55. if (dto.ReportType == 0)
  56. {
  57. var find = list.Find(p => p.BaseHttpAddr == dto.BaseHttpAddr);
  58. if (find == null)
  59. {
  60. list.Add(new ModelSvrs()
  61. {
  62. SvrType = dto.SvrType,
  63. SvrID = dto.SvrID,
  64. BaseHttpAddr = dto.BaseHttpAddr,
  65. SwaggerAddr = dto.SwaggerAddr,
  66. ReportTime = DateTime.Now,
  67. });
  68. }
  69. else
  70. {
  71. find.BaseHttpAddr = dto.BaseHttpAddr;
  72. find.SwaggerAddr = dto.SwaggerAddr;
  73. find.SvrType = dto.SvrType;
  74. find.SvrID = dto.SvrID;
  75. find.ReportTime = DateTime.Now;
  76. }
  77. }
  78. else
  79. {
  80. var find = list.Find(p => p.BaseHttpAddr == dto.BaseHttpAddr);
  81. if (find == null) return;
  82. list.Remove(find);
  83. }
  84. this.BeginInvoke(new Action(() =>
  85. {
  86. gridView1.RefreshData();
  87. }));
  88. }
  89. catch (Exception ex)
  90. {
  91. Serilog.Log.Error(ex, "处理服务状态上报异常");
  92. }
  93. });
  94. while (true)
  95. {
  96. try
  97. {
  98. List<string> tmp = new List<string>();
  99. list.ForEach(t =>
  100. {
  101. if ((DateTime.Now - t.ReportTime).TotalSeconds > 20)
  102. {
  103. tmp.Add(t.BaseHttpAddr);
  104. }
  105. });
  106. var count = list.RemoveAll(p => tmp.Contains(p.BaseHttpAddr));
  107. if (count > 0)
  108. {
  109. gridView1.RefreshData();
  110. }
  111. }
  112. catch (Exception ex)
  113. {
  114. Serilog.Log.Error(ex, "Error");
  115. }
  116. await Task.Delay(10000);
  117. }
  118. }
  119. }
  120. }