LogManager.cs 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using Aitex.Core.Util;
  6. using log4net.Core;
  7. using System.Diagnostics;
  8. namespace Aitex.Core.RT.Log
  9. {
  10. public class LogManager : ICommonLog
  11. {
  12. PeriodicJob _loggingJob;
  13. FixSizeQueue<LogItem> _logQueue;
  14. LogWriter _writer;
  15. public LogManager()
  16. {
  17. }
  18. public void Initialize()
  19. {
  20. _logQueue = new FixSizeQueue<LogItem>(1000);
  21. _loggingJob = new PeriodicJob(300, this.PeriodicRun, "Save Log Job", true);
  22. _writer = new LogWriter();
  23. LOG.InnerLogger = this;
  24. }
  25. public void Terminate()
  26. {
  27. try
  28. {
  29. if (_loggingJob != null)
  30. {
  31. _loggingJob.Stop();
  32. _loggingJob = null;
  33. }
  34. }
  35. catch (Exception ex)
  36. {
  37. System.Diagnostics.Trace.WriteLine(ex.Message);
  38. }
  39. }
  40. public void Info(string message, bool isTraceOn, string stackFile)
  41. {
  42. CacheLog(message, Level.Info, null, isTraceOn, stackFile);
  43. }
  44. public void Warning(string message, string stackFile)
  45. {
  46. CacheLog(message, Level.Warn, null, true, stackFile);
  47. }
  48. public void Error(string message, string stackFile)
  49. {
  50. CacheLog(message, Level.Error, null, true, stackFile);
  51. }
  52. public void Warning(string message, Exception ex, string stackFile)
  53. {
  54. CacheLog(message, Level.Warn, ex, true, stackFile);
  55. }
  56. public void Error(string message, Exception ex, string stackFile)
  57. {
  58. CacheLog(message, Level.Error, ex, true, stackFile);
  59. }
  60. bool PeriodicRun()
  61. {
  62. LogItem item;
  63. while (_logQueue.TryDequeue(out item))
  64. {
  65. string log = _writer.Write(item);
  66. }
  67. return true;
  68. }
  69. void CacheLog(string message, Level level, Exception exception, bool isTraceOn, string stackFile)
  70. {
  71. //if (isTraceOn)
  72. //{
  73. // System.Diagnostics.Trace.WriteLine(message + (exception == null ? "" : exception.Message));
  74. //}
  75. _logQueue.Enqueue(new LogItem(message, new StackTrace(true).GetFrame(5), level, exception, stackFile));
  76. }
  77. }
  78. }