SonopostLogEngine.cs 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  1. using System;
  2. using System.IO;
  3. using System.Linq;
  4. using System.Text;
  5. using Vinno.FIS.Sonopost.Common;
  6. using Vinno.IUS.Common.Log;
  7. namespace Vinno.FIS.Sonopost.Helpers
  8. {
  9. public class SonopostLogEngine : LogEngine
  10. {
  11. private const string InfoTag = "I ; ";
  12. private const string DebugTag = "D ; ";
  13. private const string WarnTag = "W ; ";
  14. private const string ErrorTag = "E ; ";
  15. private const string VerboseTag = "V ; ";
  16. private const string UserOperationTag = "U ; ";
  17. private StreamWriter _logWriter;
  18. private readonly object _mutex = new object();
  19. private DateTime _date;
  20. private bool _disposed;
  21. public SonopostLogEngine()
  22. {
  23. var freeSpace = SystemHelper.GetHardDiskFreeSpace(AppDomain.CurrentDomain.BaseDirectory);
  24. if (freeSpace <= 10)//小于10个G
  25. {
  26. string[] logsType =
  27. {
  28. "Logs",
  29. "SmartLogs",
  30. "TRTCClientLogs",
  31. "TRTCLogs"
  32. };
  33. foreach (var type in logsType)
  34. {
  35. var logDirectory = Path.Combine(SonopostConstants.DataFolder, type);
  36. RemoveOldLogs(logDirectory);
  37. }
  38. }
  39. }
  40. ~SonopostLogEngine()
  41. {
  42. DoDispose();
  43. }
  44. public override void Write(LogLevel level, string msg)
  45. {
  46. lock (_mutex)
  47. {
  48. var now = DateTime.Today.AddHours(DateTime.Now.Hour);
  49. if (now != _date)
  50. {
  51. InitializeLogger();
  52. _date = now;
  53. }
  54. try
  55. {
  56. var message = RecombinateMessage(level, msg);
  57. WriteMessage(message);
  58. }
  59. catch (Exception)
  60. {
  61. // There is exception during writing log, so just ignore
  62. }
  63. }
  64. }
  65. private void InitializeLogger()
  66. {
  67. var today = DateTime.Today;
  68. var parentLogDirectory = Path.Combine(SonopostConstants.DataFolder, "Logs");
  69. var logDirectory = Path.Combine(parentLogDirectory, today.Year.ToString(), today.Month.ToString("D2"), today.Day.ToString("D2"));
  70. DirectoryHelper.CreateDirectory(logDirectory);
  71. var now = DateTime.Now;
  72. var logTag = $"{now:yyyyMMddHH}";
  73. var logFileName = $"Log_{logTag}.log";
  74. var logFilePath = Path.Combine(logDirectory, logFileName);
  75. if (!File.Exists(logFilePath))
  76. {
  77. _logWriter?.Dispose();
  78. var logFileStream = new FileStream(logFilePath, FileMode.Create, FileAccess.ReadWrite, FileShare.ReadWrite);
  79. _logWriter = new StreamWriter(logFileStream);
  80. }
  81. else
  82. {
  83. _logWriter?.Dispose();
  84. var logFileStream = new FileStream(logFilePath, FileMode.Open, FileAccess.ReadWrite, FileShare.ReadWrite);
  85. logFileStream.Position = logFileStream.Length;
  86. _logWriter = new StreamWriter(logFileStream);
  87. }
  88. }
  89. private void WriteMessage(string message)
  90. {
  91. _logWriter.WriteLine(message);
  92. _logWriter.Flush();
  93. }
  94. private string RecombinateMessage(LogLevel level, string msg)
  95. {
  96. var now = DateTime.Now;
  97. StringBuilder sb = new StringBuilder();
  98. sb.Append($"[{now:yyyyMMddHHmmss},{now.Millisecond:d3}]-");
  99. string message = msg;
  100. if (level == LogLevel.Error)
  101. {
  102. sb.Append(ErrorTag);
  103. }
  104. else if (level == LogLevel.Warn)
  105. {
  106. sb.Append(WarnTag);
  107. }
  108. else if (level == LogLevel.Info)
  109. {
  110. sb.Append(InfoTag);
  111. }
  112. else if (level == LogLevel.Verbose)
  113. {
  114. sb.Append(VerboseTag);
  115. }
  116. else if (level == LogLevel.Debug)
  117. {
  118. sb.Append(DebugTag);
  119. }
  120. else if (level == LogLevel.UserOperation)
  121. {
  122. sb.Append(UserOperationTag);
  123. }
  124. sb.Append(message);
  125. return sb.ToString();
  126. }
  127. private void RemoveOldLogs(string logDirectory)
  128. {
  129. if (Directory.Exists(logDirectory))
  130. {
  131. var folders = Directory.GetDirectories(logDirectory);
  132. foreach (var folder in folders)
  133. {
  134. RemoveOldLogs(folder);
  135. }
  136. //删除超过7天的日志
  137. var files = Directory.GetFiles(logDirectory).Select(m => new FileInfo(m))
  138. .Where(t => t.Exists && DateTime.Now - t.CreationTime >= TimeSpan.FromDays(7));
  139. foreach (var file in files)
  140. {
  141. file.Delete();
  142. }
  143. if (Directory.GetFiles(logDirectory).Count() == 0 && Directory.GetDirectories(logDirectory).Count() == 0)
  144. {
  145. Directory.Delete(logDirectory);
  146. }
  147. }
  148. }
  149. private void DoDispose()
  150. {
  151. if (!_disposed)
  152. {
  153. _logWriter?.Dispose();
  154. _disposed = true;
  155. }
  156. }
  157. public override void Dispose()
  158. {
  159. DoDispose();
  160. GC.SuppressFinalize(this);
  161. }
  162. }
  163. }