MainForm.cs 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Configuration;
  4. using System.Diagnostics;
  5. using System.IO;
  6. using System.Linq;
  7. using System.Reflection;
  8. using System.Threading.Tasks;
  9. using System.Windows.Forms;
  10. using XdCxRhDW.Dto;
  11. using XdCxRhDW.Framework;
  12. using XdCxRhDW.UI.Lib;
  13. using XdCxRhDW.WebApi;
  14. namespace GpuCgServer
  15. {
  16. public partial class MainForm : Form
  17. {
  18. private EnumSvrType svrType = EnumSvrType.GpuCgSvr;
  19. public string platAddr;
  20. public MainForm()
  21. {
  22. InitializeComponent();
  23. LogUI.Logger = info =>
  24. {
  25. try
  26. {
  27. this.Invoke(new Action(() =>
  28. {
  29. this.listBox1.Items.Insert(0, $"{info.LogTime:yyyyMMddHHmmss.fff}--{info.Msg}");
  30. if (this.listBox1.Items.Count > 1000)
  31. this.listBox1.Items.RemoveAt(this.listBox1.Items.Count - 1);
  32. }));
  33. }
  34. catch
  35. { }
  36. };
  37. }
  38. private async void MainForm_LoadAsync(object sender, EventArgs e)
  39. {
  40. if (Debugger.IsAttached)//结束已启动的进程,方便调试
  41. {
  42. var pros = Process.GetProcessesByName(Assembly.GetExecutingAssembly().GetName().Name).OrderBy(p => p.StartTime).ToList();
  43. pros.RemoveAt(pros.Count - 1);
  44. foreach (var item in pros)
  45. {
  46. try
  47. {
  48. item.Kill();
  49. }
  50. catch
  51. { }
  52. }
  53. }
  54. var port = AppConfigHelper.Get<int>("LocalHttpPort");
  55. var svrID = AppConfigHelper.Get("SvrID");
  56. string posPlatformAddr = null;
  57. if (!string.IsNullOrWhiteSpace(platAddr))//有命令行传递优先使用命令行传递,否则再使用配置
  58. posPlatformAddr = platAddr;
  59. else
  60. posPlatformAddr = AppConfigHelper.Get("PosPlatformAddr");
  61. posPlatformAddr = posPlatformAddr.AppendUrlSuffix("api/");
  62. LogUI.BaseUrl = posPlatformAddr;
  63. this.Text = svrType.GetEnumDisplayName() + "-" + svrID;
  64. string localIp;
  65. string getIpUrl = posPlatformAddr.AppendUrlSuffix("task/getclientip");
  66. while (true)
  67. {
  68. try
  69. {
  70. var rsp = await HttpHelper.GetRequestAsync<string>(getIpUrl);
  71. if (rsp.code == 0)
  72. {
  73. await LogUI.Error(rsp.msg);
  74. return;
  75. }
  76. else
  77. {
  78. localIp = rsp.data;
  79. }
  80. break;
  81. }
  82. catch (Exception ex)
  83. {
  84. await LogUI.Error($"无法连接到平台{getIpUrl},请检测地址是否正确并确保平台防火墙允许端口通过", ex);
  85. await Task.Delay(5000);
  86. }
  87. }
  88. await LogUI.Info($"本机IP={localIp}");
  89. Startup.Start(port, $"{System.Reflection.Assembly.GetExecutingAssembly().GetName().Name}.xml", "XdCxRhDW.Dto.xml");
  90. await LogUI.Info($"服务启动成功.接口地址http://{localIp}:{port}/swagger");
  91. string url = posPlatformAddr.AppendUrlSuffix("SvrReport/Report");
  92. _ = ClearLocalFile();
  93. bool preSucceed = false;
  94. while (!this.Disposing)
  95. {
  96. try
  97. {
  98. var res = await HttpHelper.PostRequestAsync<object>(url, new SvrStateReportDto()
  99. {
  100. SvrType = svrType,
  101. SvrID = svrID,
  102. ReportType = 0,
  103. BaseHttpAddr = $"http://{localIp}:{port}",
  104. SwaggerAddr = $"http://{localIp}:{port}/Swagger",
  105. });
  106. if (res.code != 200)
  107. {
  108. await LogUI.Error($"状态上报异常[url={url}].{res.msg}");
  109. preSucceed = false;
  110. }
  111. else
  112. {
  113. if (!preSucceed)
  114. await LogUI.Info($"状态上报成功![url={url}]");
  115. preSucceed = true;
  116. }
  117. }
  118. catch (Exception ex)
  119. {
  120. await LogUI.Error($"状态上报异常[url={url}]", ex);
  121. preSucceed = false;
  122. }
  123. await Task.Delay(10000);
  124. }
  125. }
  126. private void MainForm_FormClosed(object sender, FormClosedEventArgs e)
  127. {
  128. try
  129. {
  130. var port = AppConfigHelper.Get<int>("LocalHttpPort");
  131. var svrID = AppConfigHelper.Get("SvrID");
  132. var posPlatformAddr = AppConfigHelper.Get("PosPlatformAddr").AppendUrlSuffix("api/");
  133. string url = posPlatformAddr.AppendUrlSuffix("SvrReport/Report");
  134. var localIp = IpHelper.GetLocalIp();
  135. _ = HttpHelper.PostRequestAsync<object>(url, new SvrStateReportDto()
  136. {
  137. SvrID = svrID,
  138. SvrType = svrType,
  139. ReportType = 1,
  140. BaseHttpAddr = $"http://{localIp}:{port}",
  141. });
  142. }
  143. catch (Exception ex)
  144. {
  145. _ = LogUI.Error("状态上报异常", ex);
  146. }
  147. }
  148. //清理10分钟之前的文件
  149. private async Task ClearLocalFile()
  150. {
  151. while (true)
  152. {
  153. try
  154. {
  155. var uploadFolder = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "wwwroot");
  156. var files = Directory.EnumerateFiles(uploadFolder);
  157. foreach (var file in files)
  158. {
  159. FileInfo info = new FileInfo(file);
  160. if (info.CreationTime < DateTime.Now.AddMinutes(-10))
  161. {
  162. try
  163. {
  164. info.Delete();
  165. }
  166. catch
  167. {
  168. }
  169. }
  170. }
  171. }
  172. catch (Exception ex)
  173. {
  174. await LogUI.Error("清理wwwroot历史文件异常", ex);
  175. }
  176. await Task.Delay(60 * 1000);
  177. }
  178. }
  179. }
  180. }