.NET 日志系统2

上一篇文章是将日志打印到控制台,这篇文章将日志写入到文本文件中。

文本日志一般按照日期区分

  1. 如何避免文本日志把磁盘撑爆?

    限制日志总个数或者总大小

  2. 如何避免一个日志文件太大?

    限制单个文件大小

使用NLOG

  1. NuGet安装:NLog.Extensions.Logging
  2. 在项目根目录下创建nlog.config
  3. 增加logBuilder.AddNLog()

nlog.config

nlog.config直接去GitHub复制官方的就行了,根据自己的项目版本去选择

https://github.com/NLog/NLog/wiki/Getting-started-with-ASP.NET-Core-6

需要注意的是文件位置需要更改,可以放D盘或者项目根目录如"internal-nlog-AspNetCore.txt"

  • type="File" 指明为文件
  • fileName 生成的文件名
  • layout 指文件的输出格式

AddNLog

与上一篇文章用的同一个列子,添加logBuilder.AddNLog();

services.AddLogging(logBuilder =>
{
logBuilder.AddConsole(); //如果使用NLog建议只保留logBuilder.AddNLog();
logBuilder.AddNLog();
logBuilder.SetMinimumLevel(LogLevel.Trace);
});

效果展示

深入NLOG

日志过滤

按照不同级别输出,通过不同的命名空间实现不同的日志文件的输出。

首先新增一个Test2类,并将命名空间设置为SystemServices

namespace SystemServices;
public class Test2
{
private readonly ILogger<Test2> _logger; public Test2(ILogger<Test2> logger)
{
_logger = logger;
}
......
}

同样需要使用这个类的方法,我们循环1万次

services.AddScoped<Test2>();

var test2 = sp.GetRequiredService<Test2>();
for (int i = 0; i < 10000; i++)
{
test1.Test();
test2.Test();
}

修改config配置文件

<?xml version="1.0" encoding="utf-8" ?>
<nlog xmlns="http://www.nlog-project.org/schemas/NLog.xsd"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">=
<targets>
<target name="defaultFile" xsi:type="File" fileName="logs/log-${shortdate}.log"
layout="${date}|${level:uppercase=true}|${looger}|${message}|${exception:format=ToString}"/>
<target name="sysServicesFile" xsi:type="File" archiveAboveSize="1000000" maxArchiveFiles="3"
fileName="logs/sysServices-${shortdate}.log"
layout="${date}|${level:uppercase=true}|${looger}|${message}|${exception:format=ToString}"/>
<target name="targetConsole" xsi:type="ColoredConsole"
layout="${date}|${level:uppercase=true}|${looger}|${message}|${exception:format=ToString}"/>
</targets>
<rules>
<logger name="*" minlevel="Warn" maxlevel="Fatal" writeTo="targetConsole" />
<logger name="SystemServices.*" minlevel="Trace" writeTo="sysServicesFile" final="true"/>
<logger name="*" minlevel="Trace" writeTo="defaultFile" />
</rules>
</nlog>

通过设置rules的name通过不同的命名空间去输出不同的日志文件

<logger name="SystemServices.*" minlevel="Trace" writeTo="sysServicesFile" final="true"/>

匹配它的输出到sysServicesFile中,不匹配的则往下走匹配到defaultFile中。

生成了如下几个日志文件

参数解释

  1. archiveAboveSize为单个日志文件超过多少直接就把日志存档,单位为字节。
  2. maxArchiveFiles,指定文件存档的数量,如果不设定这个参数,则文件数量会一直增加。
  3. maxArchiveDays参数设定保存若干天的日志存档。

rules

  1. rules节点下可以添加多个logger,每个logger都有名字(name属性),name是通配符格式的。
  2. logger节点的minlevel属性和Maxlevel属性,表示这个logger接受日志的最低级别和最高级别。
  3. 日志输出时,会从上往下匹配rules节点下所有的logger,若发现当前日志的分类和level符合这个logger的name通配符,就会把日志输出给这个logger。如果匹配多个logger,就把这条日志输出给多个logger,但是如果一个logger设置了final="true",那么如果匹配到这个logger,就不会继续向下匹配其他logger了。

NLog其他

  1. NLog部分功能和.NET的Loggin重复,比如分类、分级、各种Provider。
  2. 为了避免冲突,如果用NLog,建议不要再配置.NET的分级等(具体用法见微软文档)

参考资料

每日一道面试题

C#中的委托是什么?事件是不是一种委托?

答 : 委托可以把一个方法作为参数代入另一个方法,委托可以理解为指向一个函数的引用。事件是一种特殊的委托。

.NET 认识日志系统-2的更多相关文章

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

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

  2. Atitit.日志系统slf4j的使用

    Atitit.日志系统slf4j的使用 SLF4J: Class path contains multiple SLF4J bindings. SLF4J: Found binding in [jar ...

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

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

  4. 使用Slf4j集成Log4j2构建项目日志系统的完美解决方案

    一.背景 最近因为公司项目性能需要,我们考虑把以前基于的log4j的日志系统重构成基于Slf4j和log4j2的日志系统,因为,使用slf4j可以很好的保证我们的日志系统具有良好的兼容性,兼容当前常见 ...

  5. 日志系统实战(三)-分布式跟踪的Net实现

    介绍 在大型系统开发调试中,跨系统之间联调开始变得不好使了.莫名其妙一个错误爆出来了,日志虽然有记录,但到底是哪里出问题了呢? 是Ios端参数传的不对?还是A系统或B系统提供的接口导致?相信有不少人遇 ...

  6. 日志系统实战(一)—AOP静态注入

    背景 近期在写日志系统,需要在运行时在函数内注入日志记录,并附带函数信息,这时就想到用Aop注入的方式. AOP分动态注入和静态注入两种注入的方式. 动态注入方式 利用Remoting的Context ...

  7. Android性能优化之UncaughtExceptionHandler定制自己的错误日志系统

    前言: 每当我们app测试的时候,测试人员总是对我们说这里崩溃了,那里挂掉了!我们只能默默接受,然后尝试着重现bug,更可悲的是有时候bug很难复现,为了解决这种现状所以我们要尝试这建立一个自己的bu ...

  8. [Asp.net 5] Logging-其他日志系统的实现

    Microsoft.Framework.Logging.NLog 使用Nlog扩展日志系统:按照我们上节说的,对于扩展的日志系统都要实现俩个接口ILogger.ILoggerProvider.所以在当 ...

  9. 【转载】scribe、chukwa、kafka、flume日志系统对比

    原文地址:http://www.ttlsa.com/log-system/scribe-chukwa-kafka-flume-log-system-contrast/ 1. 背景介绍许多公司的平台每天 ...

  10. Java日志系统及框架分析

    最近在考虑将容器(Tomcat)内的应用日志统一成slf4j + logback,主要目的有: 快速定位应用日志输出路径,方便日志的采集: 能动态调整日志的级别,方便线上问题定位: 方便在容器层面做扩 ...

随机推荐

  1. 用Multisim验证简易测谎仪

    用Multisim验证简易测谎仪 测谎仪电路如下图所示: 节点1,2之间用10M欧的电位计代表人体表电阻,原理是撒谎出汗的话,体表电阻就小.Q1,Q2构成互补音频振荡器,振荡频率由R2.C1和R12共 ...

  2. 快速了解Django:核心概念解析与实践指南

    title: 快速了解Django:核心概念解析与实践指南 date: 2024/5/1 20:31:41 updated: 2024/5/1 20:31:41 categories: 后端开发 ta ...

  3. R6_ES在互联网公司应用案例汇总参考

    Elasticsearch 是一个实时分布式搜索数据分析引擎,内部使用lucene做索引与搜索,能够解决常规和各种类型数据的存储及检索需求,典型的应用场景有:数据分析,站内搜索,ELK,电商等,主要特 ...

  4. 【Python爬虫案例】用python爬1000条哔哩哔哩搜索结果

    目录 一.爬取目标 二.讲解代码 三.同步讲解视频 四.完整源码 一.爬取目标 大家好,我是 @马哥python说 ,一名10年程序猿. 今天分享一期爬虫的案例,用python爬哔哩哔哩的搜索结果,也 ...

  5. 九、.net core(.NET 6)添加通用的Redis功能

     .net core 编写通用的Redis功能 在 Package项目里面,添加包:StackExchange.Redis: 在Common工具文件夹下,新建 Wsk.Core.Redis类库项目,并 ...

  6. Splashtop用于远程实验室的功能得到增强

    ​ 加利福尼亚州圣何塞,2020年8月11日,远程访问和远程支持解决方案的领导者Splashtop Inc. 宣布更新其 Splashtop for Remote Labs 产品.该产品旨在帮助学生通 ...

  7. MyBatis-Plus 实现多租户管理的实践

    本文主要讲解使用Mybatis-Plus结合dynamic-datasource来实现多租户管理 在现代企业应用中,多租户(Multi-Tenant)架构已经成为一个非常重要的设计模式.多租户架构允许 ...

  8. C 语言中的 sscanf 详解

    一.函数介绍 函数原型:int sscanf(const char *str, const char *format, ...); 返 回 值:成功返回匹配成功的模式个数,失败返回 -1. RETUR ...

  9. wpf 斗地主 单机版 没有机器人出牌算法

    斗地主的游戏流程实现了,剩余的音效和机器人的出牌算法,抓地主算法就用最简单的实现. 主要实现了各种牌组的组合,牌组的大小比较,总共有16种牌组 基础牌组 单张.炸弹.炸弹型飞机带对子.炸弹型飞机什么都 ...

  10. Python爬图片(面向对象版)

    import requests from lxml import etree from threading import Thread class Spider(object): def __init ...