Asp.net core3.1 框架中 采用Serilog实现log日志记录

  1. 本文以MVC框架为例,实现log记录
    在默认情况下,asp.net core有自带的可实现将日志输出到控制台,注意,此时需要,运行时,要运行自托管模式才能调出控制台。如何选择自托管模式;如下
    在这里插入图片描述

如何使用logger

 public class HomeController : Controller
    {
        private readonly ILogger<HomeController> _logger;

        public HomeController(ILogger<HomeController> logger) 
        //采用构造函数的方法注入logger。
        //其中Ilogger<>泛型后边跟引用类的名称
        {
            _logger = logger;
        }

        public IActionResult Index()
        {
            _logger.LogInformation("成功进去index方法");
            return View();
        }

        public IActionResult Privacy()
        {
            _logger.LogError("此处有警告");
            return View();
        }

        [ResponseCache(Duration = 0, Location = ResponseCacheLocation.None, NoStore = true)]
        public IActionResult Error()
        {
            return View(new ErrorViewModel { RequestId = Activity.Current?.Id ?? HttpContext.TraceIdentifier });
        }
    }

3.使用serilog日志插件

  • Serilog
  • Serilog.AspNetCore(其中此包引用了其他的输出到控制台和文件夹中的包)
    在这里插入图片描述

4.在Main()函数中,对serilog进行配置。具体代码和注释含义如下:

 public class Program
    {
        public static void Main(string[] args)
        {
            Log.Logger = new LoggerConfiguration()
                .MinimumLevel.Debug()//最小的日志输出级别是debug
                .MinimumLevel.Override("Microsoft", LogEventLevel.Information)//如果类别是Microsoft开头的话,最小输出级别information
                .Enrich.FromLogContext()
                .WriteTo.Console()//输出到控制台
                .WriteTo.File(Path.Combine("logs", @"log.text"), rollingInterval: RollingInterval.Hour)//输出到文件;第一参数输出文件的路径,第二个参数是多长时间记录一次;
                .CreateLogger();//创建文件:

            CreateHostBuilder(args).Build().Run();

        } 

        public static IHostBuilder CreateHostBuilder(string[] args) =>
            Host.CreateDefaultBuilder(args)        //这个里面有一下默认的配置,将日志输出到控制台,这就是为什么不配置上边文件,也能输出日志,可以按F12进去看看
                .ConfigureWebHostDefaults(webBuilder =>
                {
                    webBuilder.UseStartup<Startup>();
                })
            .UseSerilog();//使用serilog,将前边的默认log给覆盖掉
    }
}

5.运行结果

  • 输出了带有时间的日志信息
  • 根目录下自动生成logs文件

在这里插入图片描述
6.日志记录器的四种级别(Log4j)的要求

  • error
  • warn
  • info
  • debug
    级别由上自下依次降低

如果想有更详细的了解,请查看官方文档
官方文档连接:serilog官方文档

posted @ 2020-06-07 14:19  沧海一声笑rush  阅读(135)  评论(0编辑  收藏  举报