.NET 日志系统-3 结构化日志和集中日志服务

系列文章

结构化日志

结构化日志比普通文本更利于日志的分析,结构化日志的格式为json格式。

Serilog

使用步骤

  1. NLog也可以配置结构化日志,不过配置麻烦,推荐用Serilog。

  2. NuGet安装:Serilog.AspNetCore

    1. Log.Logger = new LoggerConfiguration()
    2. .MinimumLevel.Debug() //最低级别设置为Debug
    3. .Enrich.FromLogContext()
    4. .WriteTo.Console(new JsonFormatter())
    5. .CreateLogger();
    6. builder.AddSerilog();
  3. 要记录的结构化数据通过占位符来输出:

    1. logger.LogWarning("新增用户{@person}",new {Id=3,Name="zack"});
  4. 同样可以输出到文件、数据库、MongoDB等。

代码实现

接文章日志系统文章-1和-2(前2篇文章),代码一样,只需要在注入的时候添加第三步即可。

  1. services.AddLogging(logBuilder =>
  2. {
  3. Log.Logger = new LoggerConfiguration()
  4. .MinimumLevel.Debug() //最低级别设置为Debug
  5. .Enrich.FromLogContext()
  6. .WriteTo.Console(new JsonFormatter())
  7. .CreateLogger();
  8. logBuilder.AddSerilog();
  9. });

效果展示

模拟用户

通过第4步占位符实现结构化数据

首先在Test2中创建一个User类

  1. class User
  2. {
  3. public string Name { get; set; }
  4. public string Email { get; set; }
  5. }

然后模拟一下注册用户

  1. public void Test()
  2. {
  3. User user = new User { Name = "admin", Email = "123@qq.com" };
  4. _logger.LogDebug("注册一个用户{@person}",user);
  5. }

效果展示

集中化日志

集群化部署环境中,有N多服务器,如果每个服务器都把日志记录到本地文件,不便于查询、分析。需要把日志保存到集中化的日志服务器中。

  1. 使用NLog、Serilog等可以把日志记录到数据库、MongoDB等地方,就可以实现“结构化、集中日志服务”,不过需要自己编写日志分析程序。
  2. 公有云厂商一般都提供了日志云服务,都带有分析功能,都有对应Serilog插件,即使没有提供,开发一个插件也不麻烦。
  3. 如果没有用云平台或者想自己控制日志服务们可以使用Exceptionless或者ELK等。

Exceptionless

在线版有些功能需要收费,可以去官网用docker将Exceptionless部署到自己的服务器中。

官网:https://exceptionless.com/

找到Docs页面,列表最小面的Self Hosting中就有Docker部署的方法。

试用步骤:

Exceptionless https://be.exceptionless.io/

  1. 到Exceptionless官网注册、登录后,新建一个项目,安装向导输入公司名、项目名后,网站会给出一个apikey。
  2. 项目Nuget安装Serilog的Exceptionless插件:Serilog.Sinks.Exceptionless。
  3. 在程序最开始加上一句ExceptionlessClient.Default.Startup("拿到的apikey"),然后Serilog的配置加上一句:.WriteTo.Exceptionless()

创建项目

选择项目

马赛克部分为apikey,然后根据提示安装Nuget

  1. Install-Package Exceptionless.AspNetCore

代码实现

其实上面的官网网站讲得很清楚了,在程序的开头加上

  1. ExceptionlessClient.Default.Startup("apikey");

然后接上第二步安装Serilog.Sinks.Exceptionless,继续第三步注入的时候添加

  1. services.AddLogging(logBuilder =>
  2. {
  3. Log.Logger = new LoggerConfiguration()
  4. .MinimumLevel.Debug() //最低级别设置为Debug
  5. .Enrich.FromLogContext()
  6. .WriteTo.Console(new JsonFormatter())
  7. .WriteTo.Exceptionless() //添加这行
  8. .CreateLogger();
  9. logBuilder.AddSerilog();
  10. });

效果展示

总结

普通项目用NLog输出到文本文件即可,根据需要设定过滤、分类规则

集群部署的项目用Serilog+集中式日志服务,需要记录结构化日志,再进行结构化输出

参考链接

每日一道面试题

  1. 在.Net中所有可序列化的类都被标记为_____?

    答:[serializable]

  2. 在.Net托管代码中我们不用担心内存漏洞,这是因为有了______?

    答:GC。

.NET 日志系统-3 结构化日志和集中日志服务的更多相关文章

  1. 重新整理 .net core 实践篇—————日志系统之结构化[十八]

    前言 什么是结构化呢? 结构化,就是将原本没有规律的东西进行有规律话. 就比如我们学习数据结构,需要学习排序然后又要学习查询,说白了这就是一套,没有排序,谈如何查询是没有意义的,因为查询算法就是根据某 ...

  2. 结构化日志类库 ---- Serilog库

    在过去的几年中,结构化日志已经大受欢迎.而Serilog是 .NET 中最著名的结构化日志类库 ,我们提供了这份的精简指南来帮助你快速了解并运用它. 0. 内容 设定目标 认识Serilog 事件和级 ...

  3. Java日志系统框架的设计与实现

    推荐一篇好的文章介绍java日志系统框架的设计的文章:http://soft.chinabyte.com/database/438/11321938.shtml 文章内容总结: 日志系统对跟踪调试.程 ...

  4. Android源码——Logger日志系统

    Android的Logger日志系统是基于内核中的Logger日志驱动程序实现的. 日志保存在内核空间中 缓冲区保存日志   分类方法:日志的类型  +   日志的输出量   日志类型:   main ...

  5. PHP框架中的日志系统

    现在在一家公司做PHP后台开发程序猿(我们组没有前端,做活动时会做前端的东西),刚开始到公司的时候花2个周赶出了一个前端加后台的活动(记得当时做不出来周末加了两天班...),到现在过去4个多月了,可以 ...

  6. SLF4J日志系统在项目导入时频现的问题

    一.概述 近期在导入一个已有的项目时,日志系统出现了一个问题.错误信息如下: SLF4J问题 SLF4J: Failed to load class "org.slf4j.impl.Stat ...

  7. C++ 高性能无锁日志系统

    服务器编程中,日志系统需要满足几个条件 .高效,日志系统不应占用太多资源 .简洁,为了一个简单的日志功能引入大量第三方代码未必值得 .线程安全,服务器中各个线程都能同时写出日志 .轮替,服务器不出故障 ...

  8. java日志框架与日志系统

    日志框架:提供日志调用的接口,实际的日志输出委托给日志系统实现. JCL(Jakarta Commons Logging):比较流行的日志框架,很多框架都依赖JCL,例如Spring等. SLF4j: ...

  9. 配置Tomcat的日志系统

    成功配置tomcat的log4j日志系统,格式:HTML+每天以yyyy-mm-dd.log命名的日志文件 一.引言: 实习单位让用log4j配置webapp的日志系统,要求产生的日志文件是html格 ...

  10. iOS-创建自己的日志系统

    今天说说怎么创建自己的日志系统 先看下Xcode自己的日志(这里说的NSLog) 系统自带的NSLog打印的信息只有简单的 时间 / 项目名称 / 打印内容 内容比较简单, 很难做分类管理和写入文件 ...

随机推荐

  1. docker容器资源配额

    1.docker 容器控制CPU docker通过cgroup来控制容器使用的资源限制,可以对docker限制的资源包括cpu.内存.磁盘 1.1 指定docker容器可以使用的cpu份额 # 查看配 ...

  2. ABAP RSA 加密

    最近出现一些SAP ABAP RSA加密的需求,这里搬运一篇文章,用于学习参考. 本文链接:https://www.cnblogs.com/hhelibeb/p/14952732.html 原文标题: ...

  3. 密钥存储在过时的 trusted.gpg 密钥环中(/etc/apt/trusted.gpg)

    密钥存储在过时的 trusted.gpg 密钥环中(/etc/apt/trusted.gpg) 问题: 解决: cd /etc/opt sudo cp trusted.gpg trusted.gpg. ...

  4. Github Copilot绑定Jetbrains IDE无效的解决方案

    在Github中进行教育认证后不会自动开通Copilot功能,因此,在进行了Github教育认证之后,在使用之前要进入Github Copilot官网开通Coplilot,如果忽略了这一点,绑定Jet ...

  5. jeecg-boot中分页接口用自定义sql和实体实现

    1.controller实现 @RequestMapping(value = "/list", method = RequestMethod.GET) public Result& ...

  6. PageOffice——动态填充Word模板并在线编辑

    说明:使用pageoffice动态给word模板填充数据,插入图片.excel.word格式的文件和创建表格 一.准备工作: 本地创建一个doc或者docx格式的文件,在文件中需要插入数据的地方设置以 ...

  7. windows上安装mysql-5.6.44-winx64

    配置MySQL配置文件my.ini.datadir一般和安装目录是分开存放的 [mysqld] # 设置3306端口 port=3306 # 设置mysql的安装目录 ---这里输入你安装的文件路径- ...

  8. Python:Python字符串中的r、u和转义字符

    Python中字符串前面我们经常看到加r(R)或u/(U)的前缀,而这两个符号是什么意思呢? 1.r(R) r意为raw,表示不包含转义字符的原生字符串.常见的转义字符包括下列几种: 转义字符 描述 ...

  9. .NET 中 Channel 类简单使用

    Channel 是干什么的 The System.Threading.Channels namespace provides a set of synchronization data structu ...

  10. OpenAI“杀疯了”,GPT–4o模型保姆级使用教程!一遍就会!

    5月14日凌晨1点,OpenAI发布了名为GPT-4o 最新的大语言模型,再次引领了人工智能领域的又一创新浪潮,让整个行业都为之震动. 据OpenAI首席技术官穆里-穆拉提(Muri Murati)表 ...