zoukankan      html  css  js  c++  java
  • c# log4net 配置使用

    新增配置文件log4net.config,内容如下

    <?xml version="1.0" encoding="utf-8" ?>
    <configuration>
      <configSections>
        <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
      </configSections>
      <log4net>
        <!--新增节点说明: -->
        <!--1、复制一个appender节点,修改name,修改file,其他内容看情况修改-->
        <!--2、复制一个logger节点,修改appender-ref为步骤2中appender的name,修改name(调用WriteByLogType函数,传入的type),-->
        <appender name="InfoAppender" type="log4net.Appender.RollingFileAppender">
          <!--保存路径:下面路径项目启动的时候自动在C盘中创建log、logError文件-->
          <file value="log\Info\"/>
          <!-- 如果想在本项目中添加路径,那就直接去掉C:\  只设置log\LogError   项目启动中默认创建文件 -->
          <appendToFile value="true"/>
          <!--按照何种方式产生多个日志文件(日期[Date],文件大小[Size],混合[Composite])-->
          <rollingStyle value="Composite"/>
          <!--这是按日期产生文件夹-->
          <datePattern value="yyyy-MM\yyyy-MM-dd'.txt'"/>
          <!--是否只写到一个文件中-->
          <staticLogFileName value="false"/>
          <!--保留的log文件数量 超过此数量后 自动删除之前的   好像只有在 按Size分割时有效 设定值value="-1"为不限文件数-->
          <param name="MaxSizeRollBackups" value="100"/>
          <!--每个文件的大小。只在混合方式与文件大小方式下使用。超出大小后在所有文件名后自动增加正整数重新命名,数字最大的最早写入。可用的单位:KB|MB|GB。不要使用小数,否则会一直写入当前日志-->
          <maximumFileSize value="10240KB" />
          <!-- layout 控制Appender的输出格式,也可以是xml  一个Appender只能是一个layout-->
          <layout type="log4net.Layout.PatternLayout">
            <!--每条日志末尾的文字说明-->
            <!--输出格式 模板-->
            <!-- <param name="ConversionPattern"  value="记录时间:%date 线程ID:[%thread] 日志级别:%-5level 记录类:%logger   
            操作者ID:%property{Operator} 操作类型:%property{Action}%n  当前机器名:%property%n当前机器名及登录用户:%username %n  
            记录位置:%location%n 消息描述:%property{Message}%n   异常:%exception%n 消息:%message%newline%n%n" />-->
    
            <!--样例:2008-03-26 13:42:32,111 [10] INFO  Log4NetDemo.MainClass [(null)] - info-->
            <!--<conversionPattern value="%newline %n记录时间:%date %n线程ID:[%thread] %n日志级别: %-5level %n错误描述:%message%newline %n"/>-->
            <conversionPattern value="%n==========
                                      %n【记录时间】%date
                                      %n【记录的类】%logger 属性[%property{NDC}]
                                      %n【内容描述】%message"/>
          </layout>
        </appender>
        <appender name="ErrorAppender" type="log4net.Appender.RollingFileAppender">
          <!--保存路径:下面路径项目启动的时候自动在C盘中创建log、logError文件-->
          <file value="log\Error\"/>
          <!-- 如果想在本项目中添加路径,那就直接去掉C:\  只设置log\LogError   项目启动中默认创建文件 -->
          <appendToFile value="true"/>
          <!--按照何种方式产生多个日志文件(日期[Date],文件大小[Size],混合[Composite])-->
          <rollingStyle value="Composite"/>
          <!--这是按日期产生文件夹-->
          <datePattern value="yyyy-MM\yyyy-MM-dd'.txt'"/>
          <!--是否只写到一个文件中-->
          <staticLogFileName value="false"/>
          <!--保留的log文件数量 超过此数量后 自动删除之前的   好像只有在 按Size分割时有效 设定值value="-1"为不限文件数-->
          <param name="MaxSizeRollBackups" value="100"/>
          <!--每个文件的大小。只在混合方式与文件大小方式下使用。超出大小后在所有文件名后自动增加正整数重新命名,数字最大的最早写入。可用的单位:KB|MB|GB。不要使用小数,否则会一直写入当前日志-->
          <maximumFileSize value="10240KB" />
          <!-- layout 控制Appender的输出格式,也可以是xml  一个Appender只能是一个layout-->
          <layout type="log4net.Layout.PatternLayout">
            <!--每条日志末尾的文字说明-->
            <!--输出格式 模板-->
            <!-- <param name="ConversionPattern"  value="记录时间:%date 线程ID:[%thread] 日志级别:%-5level 记录类:%logger   
            操作者ID:%property{Operator} 操作类型:%property{Action}%n  当前机器名:%property%n当前机器名及登录用户:%username %n  
            记录位置:%location%n 消息描述:%property{Message}%n   异常:%exception%n 消息:%message%newline%n%n" />-->
    
            <!--样例:2008-03-26 13:42:32,111 [10] INFO  Log4NetDemo.MainClass [(null)] - info-->
            <!--<conversionPattern value="%newline %n记录时间:%date %n线程ID:[%thread] %n日志级别: %-5level %n错误描述:%message%newline %n"/>-->
            <conversionPattern value="%n==========
                                      %n【日志级别】%-5level
                                      %n【记录时间】%date
                                      %n【线程编号】[%thread]
                                      %n【执行时间】[%r]毫秒
                                      %n【出错文件】%F
                                      %n【出错行号】%L
                                      %n【出错的类】%logger 属性[%property{NDC}]
                                      %n【错误描述】%message
                                      %n【错误详情】%newline"/>
          </layout>
        </appender>
        <logger name="info_logo">
          <level value="ALL" />
          <appender-ref ref="InfoAppender" />
        </logger>
        <logger name="error_logo">
          <level value="ALL" />
          <appender-ref ref="ErrorAppender" />
        </logger>
      </log4net>
    </configuration>
    View Code

    写个帮助类

     public class Log4NetHelper
        {
            private static string m_logFile;
            private static Dictionary<string, log4net.ILog> m_lstLog = new Dictionary<string, log4net.ILog>();
            public static void InitLog4Net(string strLog4NetConfigFile)
            {
                log4net.Config.XmlConfigurator.Configure(new System.IO.FileInfo(strLog4NetConfigFile));
                m_logFile = strLog4NetConfigFile;
                m_lstLog["info_logo"] = log4net.LogManager.GetLogger("info_logo");
                m_lstLog["error_logo"] = log4net.LogManager.GetLogger("error_logo");
            }
    
            /// <summary>
            /// 功能描述:写入常规日志
            /// </summary>
            /// <param name="strInfoLog">strInfoLog</param>
            public static void WriteInfoLog(string strInfoLog)
            {
                if (m_lstLog["info_logo"].IsInfoEnabled)
                {
                    m_lstLog["info_logo"].Info(strInfoLog);
                }
            }
    
            /// <summary>
            /// 功能描述:写入错误日志
            /// </summary>
            /// <param name="strErrLog">strErrLog</param>
            /// <param name="ex">ex</param>
            public static void WriteErrorLog(string strErrLog, Exception ex = null)
            {
                if (m_lstLog["error_logo"].IsErrorEnabled)
                {
                    m_lstLog["error_logo"].Error(strErrLog, ex);
                }
            }
    
            /// <summary>
            /// 功能描述:写入日志
            /// </summary>
            /// <param name="strType">日志类型(对应log4net配置文件中logger.nama)</param>
            /// <param name="strLog">strLog</param>
            public static void WriteByLogType(string strType, string strLog)
            {
                if (!m_lstLog.ContainsKey(strType))
                {
                    //判断是否存在节点
                    if (!HasLogNode(strType))
                    {
                        WriteErrorLog("log4net配置文件不存在【" + strType + "】配置");
                        return;
                    }
                    m_lstLog[strType] = log4net.LogManager.GetLogger(strType);
                }
                m_lstLog[strType].Error(strLog);
            }
    
            /// <summary>
            /// 功能描述:是否存在指定的配置
            /// </summary>
            /// <param name="strNodeName">strNodeName</param>
            /// <returns>返回值</returns>
            private static bool HasLogNode(string strNodeName)
            {
                XmlDocument doc = new XmlDocument();
                doc.Load(m_logFile);
                var lstNodes = doc.SelectNodes("//configuration/log4net/logger");
                foreach (XmlNode item in lstNodes)
                {
                    if (item.Attributes["name"].Value.ToLower() == strNodeName)
                        return true;
                }
                return false;
            }
        }
    View Code

    程序启动时初始化

    Log4NetHelper.InitLog4Net(Application.StartupPath + "\log4net.config");    

    需要的地方调用函数写日志就可以了

  • 相关阅读:
    如何监控IT正常运行时间?
    系统扩展正在取代macOS内核扩展,这会对您有何影响?
    IT管理员需要的10大网络工具
    自动化管理员工生命周期,集成Ultipro
    OpManager MSP:ManageEngine的新型MSP重点网络监控解决方案
    vue中axios的使用
    vue中axios的介绍
    移动端适配--关于根元素font-size和rem
    JavaScript---数组去重
    array数组的方法
  • 原文地址:https://www.cnblogs.com/bfyx/p/9342512.html
Copyright © 2011-2022 走看看