zoukankan      html  css  js  c++  java
  • C#/.net 5.0

    控制台应用程序/.net 5.0
    引用包
    • log4net
    log4net.config【始终复制】

    说明:

    • FileAppender和RollingFileAppender都是用来将日志写入到文本文件中。但是,RollingFileAppender提供了更多的选项,可以很方便的控制何时新建一个新的文本文件。这个还是很有必要的,想象以下,你把所有的日志都记录到一个文本文件中,即使系统再小,日复一日,你也会有找不到日志的时候,何况,随着文本的增大,文本的写入与打开也会想得更加的慢,甚至出现超时。因此,主要使用RollingFileAppender写日志.
    <?xml version="1.0" encoding="utf-8"?>
    <configuration>
      <!-- Level的级别,由高到低 -->
      <!-- None > Fatal > ERROR > WARN > DEBUG > INFO > ALL-->
      <!-- 解释:如果level是ERROR,则在cs文件里面调用log4net的info()方法,则不会写入到日志文件中-->
      <log4net>
        <!--错误日志类-->
        <logger name="error">
          <!--定义记录的日志级别-->
          <level value="ALL" />
          <!--输出到文件-->
          <appender-ref ref="ErrorAppender" />
          <!--输出到控制台-->
          <appender-ref ref="ConsoleAppender"/>
        </logger>
        <!--信息日志类-->
        <logger name="info">
          <level value="ALL" />
          <appender-ref ref="InfoAppender" />
          <appender-ref ref="ConsoleAppender"/>
        </logger>
        <!--调试日志类-->
        <logger name="debug">
          <level value="ALL" />
          <appender-ref ref="DebugAppender" />
          <appender-ref ref="ConsoleAppender"/>
        </logger>
        <!--错误日志附加介质:输出到文件-->
        <!-- name属性指定其名称,type则是log4net.Appender命名空间的一个类的名称,意思是,指定使用哪种介质-->
        <appender name="ErrorAppender" type="log4net.Appender.RollingFileAppender">
          <!--日志输出到exe程序这个相对目录下-->
          <file value="Log\Error\" />
          <!--输出的日志不会覆盖以前的信息-->
          <appendToFile value="true" />
          <!--备份文件的个数-->
          <maxSizeRollBackups value="100" />
          <!--单个日志文件的最大大小-->
          <maxFileSize value="10240" />
          <!--是否使用静态文件名-->
          <staticLogFileName value="false" />
          <!--日志文件名-->
          <datePattern value="yyyyMMdd'.txt'" />
          <!--文件创建的方式,这里是以Date方式创建-->
          <rollingStyle value="Date" />
          <!--错误日志布局-->
          <layout type="log4net.Layout.PatternLayout">
            <conversionPattern value="%newline%date [Thread: %thread] %newline%message %newline"/>
          </layout>
        </appender>
        <!--信息日志附加介质:输出到文件-->
        <appender name="InfoAppender" type="log4net.Appender.RollingFileAppender">
          <!--日志目录-->
          <file value="Log\Info\" />
          <appendToFile value="true" />
          <maxFileSize value="10240" />
          <maxSizeRollBackups value="100" />
          <!--日志文件名是否为静态-->
          <staticLogFileName value="false" />
          <datePattern value="yyyyMMdd'.txt'" />
          <rollingStyle value="Date" />
          <layout type="log4net.Layout.PatternLayout">
            <conversionPattern value="%newline%date [Thread: %thread] %message %newline"/>
          </layout>
        </appender>
        <!--调试日志附加介质:输出到文件-->
        <appender name="DebugAppender" type="log4net.Appender.RollingFileAppender">
          <file value="Log\Debug\" />
          <appendToFile value="true" />
          <maxFileSize value="10240" />
          <maxSizeRollBackups value="100" />
          <staticLogFileName value="false" />
          <datePattern value="yyyyMMdd'.txt'" />
          <rollingStyle value="Date" />
          <layout type="log4net.Layout.PatternLayout">
            <conversionPattern value="%newline%date [Thread: %thread] %message %newline"/>
          </layout>
        </appender>
        <!--日志附加介质:输出到控制台-->
        <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
          <!--<mapping>
            <level value="ERROR" />
            <foreColor value="White" />
            <backColor value="Red, HighIntensity" />
          </mapping>
          <mapping>
            <level value="DEBUG" />
            <foreColor value="White" />
            <backColor value="Green" />
          </mapping>
          <mapping>
            <level value="INFO" />
            <foreColor value="White" />
            --><!--<backColor value="Yellow" />--><!--
          </mapping>-->
          <layout type="log4net.Layout.PatternLayout">
            <!--%data格式为yyyy-MM-dd HH:mm:ss,sss-->
            <conversionPattern value="%date{yyyy'-'MM'-'dd HH':'mm':'ss} [%-5level] %message%newline" />
          </layout>
          <filter type="log4net.Filter.LevelRangeFilter">
            <param name="LevelMin" value="Debug"/>
            <param name="LevelMax" value="Fatal"/>
          </filter>
        </appender>
      </log4net>
    </configuration>

    输出样式说明

    • %m(message):输出的日志消息,如ILog.Debug(…)输出的一条消息
    • %n(new line):换行
    • %d(datetime):输出当前语句运行的时刻
    • %r(run time):输出程序从运行到执行到当前语句时消耗的毫秒数
    • %t(thread id):当前语句所在的线程ID
    • %p(priority):日志的当前优先级别,即DEBUG、INFO、WARN…等
    • %c(class):当前日志对象的名称,例如:
    • %f(file):输出语句所在的文件名。
    • %l(line):输出语句所在的行号。
    • %数字:表示该项的最小长度,如果不够,则用空格填充,如%-5level表示level的最小宽度是5个字符,如果实际长度不够5个字符则以空格填充。
    控制台:LogHelper.cs
    using log4net;
    using log4net.Config;
    using log4net.Repository;
    using System.IO;
    
    public class LogHelper
    {
        private static ILoggerRepository repository { get; set; }
        private static ILog _logInfo;
        private static ILog _logError;
        private static ILog _logDebug;
        private static ILog logInfo
        {
            get
            {
                if (_logInfo == null)
                {
                    Configure();
                }
                return _logInfo;
            }
        }
        private static ILog logError
        {
            get
            {
                if (_logError == null)
                {
                    Configure();
                }
                return _logError;
            }
        }
        private static ILog logDebug
        {
            get
            {
                if (_logDebug == null)
                {
                    Configure();
                }
                return _logDebug;
            }
        }
    
        public static void Configure(string repositoryName = "NETCoreRepository", string configFile = "log4net.config")
        {
            repository = LogManager.CreateRepository(repositoryName);
            XmlConfigurator.Configure(repository, new FileInfo(configFile));
            _logInfo = LogManager.GetLogger(repositoryName, "info");
            _logError = LogManager.GetLogger(repositoryName, "error");
            _logDebug = LogManager.GetLogger(repositoryName, "debug");
        }
    
        public static void Info(string msg)
        {
            logInfo.Info(msg);
        }
    
        public static void Debug(string msg)
        {
            logError.Debug(msg);
        }
    
        public static void Error(string msg)
        {
            logError.Error(msg);
        }
    }
    .net 5.0 注入中间件方式
    引用
    • log4net
    • Microsoft.Extensions.Logging.Log4net.AspNetCore
    log4.config【始终复制】
    <?xml version="1.0" encoding="utf-8" ?>
    
    <log4net>
      <!--指定日记记录方式,以滚动文件的方式(文件记录)-->
      <appender name="RollingFile" type="log4net.Appender.RollingFileAppender">
        <!--日志路径-->
        <file value="Logmessage" />
        <!--是否是向文件中追加日志-->
        <appendToFile value="true" />
        <!--log保留天数-->
        <param name= "MaxSizeRollBackups" value= "10"/>
        <!--每个文件最大1M-->
        <param name="maximumFileSize" value="1MB" />
        <!--日志根据日期滚动-->
        <param name="RollingStyle" value="Date" />
        <!--日志文件名格式为:logs_20080831.log-->
        <param name="DatePattern" value=""logs_"yyyyMMdd".log"" />
        <!--日志文件名是否是固定不变的-->
        <param name="StaticLogFileName" value="false" />
        <!--布局-->
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%date %5level %logger.%method [%line] - MESSAGE: %message%newline %exception" />
        </layout>
      </appender>
      <root>
        <level value="ALL"/>
        <appender-ref ref="RollingFile" />
      </root>
    </log4net>
    Program.cs

    .ConfigureLogging(loggingBuilder=> 
    {
        loggingBuilder.AddLog4Net("log4net.config");
    })
    使用方式

  • 相关阅读:
    app被Rejected 的各种原因翻译
    UIView Border color
    Centos7下安装docker
    利用Yum彻底移除docker
    Docker删除全部镜像和容器
    【转】哈哈笑一笑
    【转】KAFKA分布式消息系统
    java读取properties文件
    java反序列化php序列化的对象
    Java 1.7.0_06中String类内部实现的一些变化【转】
  • 原文地址:https://www.cnblogs.com/gygtech/p/14635674.html
Copyright © 2011-2022 走看看