日志配置

<log4net debug="true">
    <root>
      <!--控制级别,由低到高: ALL|DEBUG|INFO|WARN|ERROR|FATAL|OFF-->
      <!--比如定义级别为INFO,则INFO级别向下的级别,比如DEBUG日志将不会被记录-->
      <!--如果没有定义LEVEL的值,则缺省为DEBUG-->
      <logger name="WebLogger">
        <level value="INFO" />
        <appender-ref ref="rollingFile" />
      </logger>
      <appender-ref ref="RollingLogFileAppender" />
    </root>
    <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
      <!--日志文件名开头-->
      <file value="logs\log.txt" />
      <!--多线程时采用最小锁定-->
      <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
      <!--日期的格式,每天换一个文件记录,如不设置则永远只记录一天的日志,需设置-->
      <datePattern value="yyyy\\yyyyMM\\yyyyMMdd'.txt'" />
      <!--是否追加到文件,默认为true,通常无需设置-->
      <appendToFile value="true" />
      <!--rollingStyle为Date,这种情况下每天只有一个日志-->
      <!--此时MaxSizeRollBackups和maximumFileSize的节点设置没有意义-->
      <!--<rollingStyle value="Date"/>-->
      <!--rollingStyle为Size-->
      <!--这种情况下MaxSizeRollBackups和maximumFileSize的节点设置才有意义-->
      <rollingStyle value="Size" />
      <!--每天记录的日志文件个数,与maximumFileSize配合使用-->
      <maxSizeRollBackups value="10" />
      <!--每个日志文件的最大大小-->
      <!--可用的单位:KB|MB|GB-->
      <!--不要使用小数,否则会一直写入当前日志-->
      <maximumFileSize value="5MB" />
      <!--StaticLogFileName的值如果为true,则当前日志文件(相对于历史日志文件而言)的文件名只取file参数。如果为false,则文件名取File+DatePattern-->
      <staticLogFileName value="false" />
      <!--日志格式-->
      <layout type="log4net.Layout.PatternLayout">
        <!--%m(message):输出的日志消息;
        %n(newline):换行;
        %d(datetime):输出当前语句运行的时刻;
        %r(runtime):输出程序从运行到执行到当前语句时消耗的毫秒数;
        %t(threadid):当前语句所在的线程ID ;
        %p(priority): 日志的当前日志级别;
        %c(class):当前日志对象的名称;
        %L:输出语句所在的行号;
        %F:输出语句所在的文件名; 
        %-10:表示最小长度为10,如果不够,则用空格填充;-->
        <conversionPattern value="[%-5p] %d %2rms[%t] %-22.22c{1} %-18.18M - %m%n" />
      </layout>
    </appender>
  </log4net>
WebConfig
[assembly: log4net.Config.XmlConfigurator(ConfigFile = "Config/log4net.config", Watch = true)]
AssemblyInfo
            log4net.Config.XmlConfigurator.Configure();
Global
        public void loggor(string msg)
        {
            ILog log = log4net.LogManager.GetLogger("ProductsController");
            log.Info(msg);
        }

 

posted @ 2017-06-21 15:59  前尘往事  阅读(125)  评论(0编辑  收藏  举报