zoukankan      html  css  js  c++  java
  • Asp.NetCore中集成各种日志框架

    前言

      Asp.NetCore自带日志记录功能,但提供的功能相对于第三方日志框架的来说不够“强悍”,但自身以面向接口的方式实现,很方便集成各种日志框架,这里先集成两个比较常用的日志框架,Log4Net和Serilog;

    正文

      Asp.NetCore自带日志的使用;

      1. 先创建一个WebApi项目;

      

       将launchSettings配置文件修改一下(其实就是把IIS相关配置删掉就行),即以项目的方式启动,不用IIS的方式,这样方便查看日志;

      

       2. 项目中已经集成了日志功能,打开WeatherForecastController.cs文件,构造函数就已经注入好了日志实例(.NetCore已经集成了IOC),直接用即可;

      

       3. 在WeatherForecastController的Get方法中用一把实例一把logger;

      提供了现有方法,如下

      

       使用

      

       4. 运行结果

      

       用起来是不是很简单,但是明明写了五个日志,为什么就只有三个显示了? 那是因为级别做限制了,直接修改appsettings文件即可,如果是开发环境,修改appsettings.Development.json;

       

       运行结果,写的5个日志都显示出来了:

      

       5.当我们不想看到那么多级别的日志,只关心Warn级别日志的时候,我们向上面一样可以改配置文件,也可以在代码中修改,这里在Program.cs代码中过滤一下:

      

       注:ConfigureLogging中可以进行日志相关的很多配置,大家可以下去自己尝试;

      运行效果:

      

       从上面来看,系统自带日志其实对于开发过程中调试是比较方便的,直接在控制台显示了,而且还可以指定对应级别,甚至可以自定义。但是提供的功能有限,如显示格式及存储方式目前没有提供,而成熟的第三方日志框架已经实现了(如Log4Net,Serilog),所以开始集成一把试试。

      2. 集成Log4Net;(之前我们都会以工具类的形式集成Log4Net,在这就不说那种方式了,在.NetCore中,直接接管自带的日志)

      三大步之A:引入Log4Net日志扩展包:Microsoft.Extensions.Logging.Log4Net.AspNetCore

      三大步之B:编写配置文件log4net.xml,并设置属性为始终复制;

    <?xml version="1.0" encoding="utf-8" ?>
    <log4net>
      <appender name="Info" type="log4net.Appender.RollingFileAppender">
        <file value="Log\" />
        <appendToFile value="true" />
        <rollingStyle value="Composite" />
        <maxSizeRollBackups value="-1" />
        <maximumFileSize value="10MB" />
        <staticLogFileName value="false" />
        <encoding  value="utf-8" />
        <DatePattern value="yyyy-MM-dd".txt""/>
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%date  %-5level  - %message%newline" />
        </layout>
      </appender>
    
      <appender name="Error" type="log4net.Appender.RollingFileAppender">
        <file value="Log\" />
        <appendToFile value="true" />
        <rollingStyle value="Composite" />
        <maxSizeRollBackups value="-1" />
        <maximumFileSize value="10MB" />
        <staticLogFileName value="false" />
        <encoding  value="utf-8" />
        <DatePattern value="yyyy-MM-dd".txt""/>
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%date  %-5level  - %message%newline" />
        </layout>
      </appender>
      
      <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%date %-5level - %message%newline" />
        </layout>
      </appender>
    
      <logger name="Info">
        <level value="ALL"/>
        <appender-ref ref="Info" />
      </logger>
    
      <logger name="InterfaceCall">
        <level value="ALL"/>
        <appender-ref ref="InterfaceCall" />
      </logger>
    
      <logger name="Error">
        <level value="ALL"/>
        <appender-ref ref="Error" />
      </logger>
     
      <root>
        <level value="ALL"/>
        <appender-ref ref="Info" />
        <appender-ref ref="ConsoleAppender" />
      </root>
    
    </log4net>
    

      

      三大步之C:修改Program.cs文集中的方法,见红色部分

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Threading.Tasks;
    using Microsoft.AspNetCore.Hosting;
    using Microsoft.Extensions.Configuration;
    using Microsoft.Extensions.Hosting;
    using Microsoft.Extensions.Logging;
    
    namespace IntegrateLog
    {
        public class Program
        {
            public static void Main(string[] args)
            {
                CreateHostBuilder(args).Build().Run();
            }
    
            public static IHostBuilder CreateHostBuilder(string[] args) =>
                Host.CreateDefaultBuilder(args)
                    .ConfigureWebHostDefaults(webBuilder =>
                    {
                        webBuilder.UseStartup<Startup>();
                        webBuilder.ConfigureLogging((hostingContext, builder) =>
                        {
                            //builder.AddFilter(loglevel => loglevel >= LogLevel.Warning);
                            //清楚自带的Providers
                            builder.ClearProviders();
                            builder.AddConsole();
                            builder.AddDebug();
                            builder.AddLog4Net("log4net.xml");
                        });
                    });
        }
    }
    

      看运行结果:

      控制台正常打印

      

       日志文件正常生成及写入:

      

       如上,Log4Net就集成到项目中,原来项目中使用的日志逻辑不需要进行改变,一样的写法。接下来关注Log4Net即可;

    总结

      本来想把Serilog也具体集成一下,想着步骤基本一样,若需要Serilog集成的,可以参考以上Log4Net的思路。这样集成了第三方日志框架,日志记录就更加方便了,格式和存储位置都可以任意配置,是不是很给力。

     关注公众号,每周至少更新两篇.NetCore相关文章

      

        

  • 相关阅读:
    Codeforces 662 C. Binary Table
    Codeforces 923 D. Picking Strings
    Codeforces 923 C. Perfect Security
    Codeforces 923 B. Producing Snow
    Codeforces 923 A. Primal Sport
    bzoj千题计划288:bzoj1876: [SDOI2009]SuperGCD
    Configuring HugePages for Oracle on Linux (x86-64)
    Oracle 11g新参数USE_LARGE_PAGES与AMM使用 (转载)
    Linux Hugepage ,AMM及 USE_LARGE_PAGES for oracle 11G(转载)
    Oracle教程:如何诊断节点重启问题(转载)
  • 原文地址:https://www.cnblogs.com/zoe-zyq/p/12900636.html
Copyright © 2011-2022 走看看