- 本文以MVC框架为例,实现log记录
在默认情况下,asp.net core有自带的可实现将日志输出到控制台,注意,此时需要,运行时,要运行自托管模式才能调出控制台。如何选择自托管模式;如下
如何使用logger
public class HomeController : Controller
{
private readonly ILogger<HomeController> _logger;
public HomeController(ILogger<HomeController> logger)
{
_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()
.MinimumLevel.Override("Microsoft", LogEventLevel.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)
.ConfigureWebHostDefaults(webBuilder =>
{
webBuilder.UseStartup<Startup>();
})
.UseSerilog();
}
}
5.运行结果
- 输出了带有时间的日志信息
- 根目录下自动生成logs文件
6.日志记录器的四种级别(Log4j)的要求
- error
- warn
- info
- debug
级别由上自下依次降低
如果想有更详细的了解,请查看官方文档
官方文档连接:serilog官方文档
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)