tnblog
首页
视频
资源
登录

.net core 结构化日志组件Serilog:记录对查询分析友好的日志

6277人阅读 2020/7/22 10:17 总访问:3467287 评论:0 收藏:0 手机
分类: .net后台框架

.netcore

.net core 结构化日志组件Serilog:记录对查询分析友好的日志


结构化日志的好处

  • 易于检索
  • 易于分析统计

场景举例

  • 实现日志警告
  • 实现上下文的关联
  • 实现与追踪系统集成

内容实践

安装相关依赖包

https://www.nuget.org/packages/Serilog.AspNetCore

配置日志级别 appsetting.json

  1. {
  2. "Logging": {
  3. "LogLevel": {
  4. "Default": "Information",
  5. "Microsoft": "Warning",
  6. "Microsoft.Hosting.Lifetime": "Information"
  7. }
  8. },
  9. "Serilog": {
  10. "MinimumLevel": {
  11. "Default": "Information",
  12. "Override": {
  13. "Microsoft": "Information",
  14. "System": "Information"
  15. }
  16. }
  17. },
  18. "AllowedHosts": "*"
  19. }
Program.cs
  1. public class Program
  2. {
  3. public static IConfiguration Configuration => new ConfigurationBuilder()
  4. .SetBasePath(Directory.GetCurrentDirectory())
  5. .AddJsonFile("appsettings.json", optional: false, reloadOnChange: true)
  6. .AddJsonFile($"appsettings.{Environment.GetEnvironmentVariable("ASPNETCOre_ENVIRONMENT") ?? "Production"}.json")
  7. .AddEnvironmentVariables()
  8. .Build();
  9. public static int Main(string[] args)
  10. {
  11. Log.Logger = new LoggerConfiguration().ReadFrom.Configuration(Configuration)
  12. .MinimumLevel.Debug()//最小级别
  13. .Enrich.FromLogContext()//使用Serilog.Context.LogContext中的属性来丰富日志事件。
  14. .WriteTo.Console(new RenderedCompactJsonFormatter())//控制台使用Json格式输出
  15. .WriteTo.File(formatter: new CompactJsonFormatter(), "logs\\myapp.txt", rollingInterval: RollingInterval.Day)//天为单位以Json格式输出到指定的文件中去
  16. .CreateLogger();//创建日志
  17. try
  18. {
  19. Log.Information("Starting web host");
  20. CreateHostBuilder(args).Build().Run();
  21. return 0;
  22. }
  23. catch (Exception ex)
  24. {
  25. Log.Fatal(ex, "Host terminated unexpectedly");
  26. return 1;
  27. }
  28. finally
  29. {
  30. Log.CloseAndFlush();
  31. }
  32. }
  33. public static IHostBuilder CreateHostBuilder(string[] args) =>
  34. Host.CreateDefaultBuilder(args)
  35. .ConfigureWebHostDefaults(webBuilder =>
  36. {
  37. webBuilder.UseStartup<Startup>();
  38. })
  39. .UseSerilog(dispose:true);
  40. }
WeatherForecastController.cs
  1. [ApiController]
  2. [Route("[controller]")]
  3. public class WeatherForecastController : ControllerBase
  4. {
  5. private static readonly string[] Summaries = new[]
  6. {
  7. "Freezing", "Bracing", "Chilly", "Cool", "Mild", "Warm", "Balmy", "Hot", "Sweltering", "Scorching"
  8. };
  9. private readonly ILogger<WeatherForecastController> _logger;
  10. public WeatherForecastController(ILogger<WeatherForecastController> logger)
  11. {
  12. _logger = logger;
  13. }
  14. [HttpGet]
  15. public IEnumerable<WeatherForecast> Get()
  16. {
  17. _logger.LogInformation("Create a log data");
  18. var rng = new Random();
  19. return Enumerable.Range(1, 5).Select(index => new WeatherForecast
  20. {
  21. Date = DateTime.Now.AddDays(index),
  22. TemperatureC = rng.Next(-20, 55),
  23. Summary = Summaries[rng.Next(Summaries.Length)]
  24. })
  25. .ToArray();
  26. }
  27. }

运行效果

运1

这里我们在最后一行看得到Create a log data,但日志太多了很难看到我们想要的东西,所以我们可以对appsetting.json进行修改,将日志级别调高为Error

  1. {
  2. "Logging": {
  3. "LogLevel": {
  4. "Default": "Information",
  5. "Microsoft": "Warning",
  6. "Microsoft.Hosting.Lifetime": "Information"
  7. }
  8. },
  9. "Serilog": {
  10. "MinimumLevel": {
  11. "Default": "Error",
  12. "Override": {
  13. "Microsoft": "Error",
  14. "System": "Information"
  15. }
  16. }
  17. },
  18. "AllowedHosts": "*"
  19. }

第二次运行


欢迎加群讨论技术,1群:677373950(满了,可以加,但通过不了),2群:656732739

评价

剑轩

2019/8/22 10:15:02

c语言很厉害,各种东西都可以写

net core 使用 EF Code First

下面这些内容很老了看这篇:https://www.tnblog.net/aojiancc2/article/details/5365 项目使用多层,把数据库访问...

.net mvc分部页,.net core分部页

.net分部页的三种方式第一种:@Html.Partial(&quot;_分部页&quot;)第二种:@{ Html.RenderPartial(&quot;分部页&quot;);}...

StackExchange.Redis操作redis(net core支持)

官方git开源地址https://github.com/StackExchange/StackExchange.Redis官方文档在docs里边都是官方的文档通过nuget命令下...

.net core 使用session

tip:net core 2.2后可以直接启用session了,不用在自己添加一次session依赖,本身就添加了使用nuget添加引用Microsoft.AspN...

通俗易懂,什么是.net?什么是.net Framework?什么是.net core?

朋友圈@蓝羽 看到一篇文章写的太详细太通俗了,搬过来细细看完,保证你对.NET有个新的认识理解原文地址:https://www.cnblo...

asp.net core2.0 依赖注入 AddTransient与AddScoped的区别

asp.net core主要提供了三种依赖注入的方式其中AddTransient与AddSingleton比较好区别AddTransient瞬时模式:每次都获取一...

.net core 使用 Kestrel

Kestrel介绍 Kestrel是一个基于libuv的跨平台web服务器 在.net core项目中就可以不一定要发布在iis下面了Kestrel体验可以使...

net core中使用cookie

net core中可以使用传统的cookie也可以使用加密的cookieNET CORE中使用传统cookie设置:HttpContext.Response.Cookies.Appe...

net core项目结构简单分析

一:wwwrootwwwroot用于存放网站的静态资源,例如css,js,图片与相关的前端插件等lib主要是第三方的插件,例如微软默认引用...

net core使用EF之DB First

一.新建一个.net core的MVC项目新建好项目后,不能像以前一样直接在新建项中添加ef了,需要用命令在添加ef的依赖二.使用Nug...

.net core使用requestresponse下载文件下载excel等

使用request获取内容net core中request没有直接的索引方法,需要点里边的Query,或者formstringbase64=Request.Form[&quot;f...

iframe自适应高度与配合net core使用

去掉iframe边框frameborder=&quot;0&quot;去掉滚动条scrolling=&quot;no&quot;iframe 自适应高度如果内容是固定的,那么就...

net core启动报错Unable to configure HTTPS endpoint. No server certificate was specified

这是因为net core2.1默认使用的https,如果使用Kestrel web服务器的话没有安装证书就会报这个错其实仔细看他的错误提示,其...

net core中使用url编码与解码操作

net core中暂时还没有以前asp.net与mvc中的server对象。获取url的编码与解码操作不能使用以前的server对象来获取。使用的是...

下载net core

官方下载地址:https://dotnet.microsoft.com/download 进来之后就可以看到最新的下载版本可以直接点击下载,也可以下载其...

net core使用依赖注入来装载EF的上下文对象

妹子情人节快乐~.net core中用了不少的依赖注入,官方文档中也推荐使用。这样使用依赖注入来管理ef对象,还是比较科学,比如...
这一世以无限游戏为使命!
排名
2
文章
634
粉丝
44
评论
93
docker中Sware集群与service
尘叶心繁 : 想学呀!我教你呀
一个bug让程序员走上法庭 索赔金额达400亿日元
叼着奶瓶逛酒吧 : 所以说做程序员也要懂点法律知识
.net core 塑形资源
剑轩 : 收藏收藏
映射AutoMapper
剑轩 : 好是好,这个对效率影响大不大哇,效率高不高
ASP.NET Core 服务注册生命周期
剑轩 : http://www.tnblog.net/aojiancc2/article/details/167
ICP备案 :渝ICP备18016597号-1
网站信息:2018-2025TNBLOG.NET
技术交流:群号656732739
联系我们:contact@tnblog.net
公网安备:50010702506256
欢迎加群交流技术