Asp.net core3.1 框架中 采用Serilog实现log日志记录
- 本文以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官方文档