LoggerExtension.cs 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using Microsoft.Extensions.Logging;
  6. using SuperSocket.Common;
  7. using SuperSocket.SocketBase.Logging;
  8. namespace SuperSocket.SocketBase
  9. {
  10. /// <summary>
  11. /// Logger extension class
  12. /// </summary>
  13. public static class LoggerExtension
  14. {
  15. private readonly static string m_SessionInfoTemplate = "Session: {0}/{1}";
  16. /// <summary>
  17. /// Logs the error
  18. /// </summary>
  19. /// <param name="logger">The logger.</param>
  20. /// <param name="session">The session.</param>
  21. /// <param name="title">The title.</param>
  22. /// <param name="e">The e.</param>
  23. public static void LogError(this ILogger logger, ISessionBase session, Exception e)
  24. {
  25. logger.LogError(string.Format(m_SessionInfoTemplate, session.SessionID, session.RemoteEndPoint) + Environment.NewLine, e);
  26. }
  27. /// <summary>
  28. /// Logs the error
  29. /// </summary>
  30. /// <param name="logger">The logger.</param>
  31. /// <param name="session">The session.</param>
  32. /// <param name="title">The title.</param>
  33. /// <param name="e">The e.</param>
  34. public static void LogError(this ILogger logger, ISessionBase session, string title, Exception e)
  35. {
  36. logger.LogError(string.Format(m_SessionInfoTemplate, session.SessionID, session.RemoteEndPoint) + Environment.NewLine + title, e);
  37. }
  38. /// <summary>
  39. /// Logs the error
  40. /// </summary>
  41. /// <param name="logger">The logger.</param>
  42. /// <param name="session">The session.</param>
  43. /// <param name="message">The message.</param>
  44. public static void LogError(this ILogger logger, ISessionBase session, string message)
  45. {
  46. logger.LogError(string.Format(m_SessionInfoTemplate, session.SessionID, session.RemoteEndPoint) + Environment.NewLine + message);
  47. }
  48. /// <summary>
  49. /// Logs the information
  50. /// </summary>
  51. /// <param name="logger">The logger.</param>
  52. /// <param name="session">The session.</param>
  53. /// <param name="message">The message.</param>
  54. public static void LogInfo(this ILogger logger, ISessionBase session, string message)
  55. {
  56. string info = string.Format(m_SessionInfoTemplate, session.SessionID, session.RemoteEndPoint) + Environment.NewLine + message;
  57. logger.LogInformation(info);
  58. }
  59. /// <summary>
  60. /// Logs the debug message
  61. /// </summary>
  62. /// <param name="logger">The logger.</param>
  63. /// <param name="session">The session.</param>
  64. /// <param name="message">The message.</param>
  65. public static void LogDebug(this ILogger logger, ISessionBase session, string message)
  66. {
  67. logger.LogDebug(string.Format(m_SessionInfoTemplate, session.SessionID, session.RemoteEndPoint) + Environment.NewLine + message);
  68. }
  69. private const string m_PerfLogName = "Perf";
  70. private static ILogger m_PerfLog;
  71. /// <summary>
  72. /// Logs the performance message
  73. /// </summary>
  74. /// <param name="appServer">The app server.</param>
  75. /// <param name="message">The message.</param>
  76. public static void LogPerf(this IAppServer appServer, string message)
  77. {
  78. if (m_PerfLog == null)
  79. {
  80. lock (m_PerfLogName)
  81. {
  82. if (m_PerfLog == null)
  83. {
  84. m_PerfLog = appServer.LogFactory.CreateLogger(m_PerfLogName);
  85. }
  86. }
  87. }
  88. if (m_PerfLog != null)
  89. m_PerfLog.LogInformation(message);
  90. }
  91. }
  92. }