.NET 认识日志系统-2
.NET 日志系统2
上一篇文章是将日志打印到控制台,这篇文章将日志写入到文本文件中。
文本日志一般按照日期区分
如何避免文本日志把磁盘撑爆?
限制日志总个数或者总大小
如何避免一个日志文件太大?
限制单个文件大小
使用NLOG
- NuGet安装:
NLog.Extensions.Logging - 在项目根目录下创建
nlog.config - 增加
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中。
生成了如下几个日志文件


参数解释
- archiveAboveSize为单个日志文件超过多少直接就把日志存档,单位为字节。
- maxArchiveFiles,指定文件存档的数量,如果不设定这个参数,则文件数量会一直增加。
- maxArchiveDays参数设定保存若干天的日志存档。
rules
- rules节点下可以添加多个logger,每个logger都有名字(name属性),name是通配符格式的。
- logger节点的minlevel属性和Maxlevel属性,表示这个logger接受日志的最低级别和最高级别。
- 日志输出时,会从上往下匹配rules节点下所有的logger,若发现当前日志的分类和level符合这个logger的name通配符,就会把日志输出给这个logger。如果匹配多个logger,就把这条日志输出给多个logger,但是如果一个logger设置了final="true",那么如果匹配到这个logger,就不会继续向下匹配其他logger了。
NLog其他
- NLog部分功能和.NET的Loggin重复,比如分类、分级、各种Provider。
- 为了避免冲突,如果用NLog,建议不要再配置.NET的分级等(具体用法见微软文档)
参考资料
- 【.NET 6教程,.Net Core 2022视频教程,杨中科主讲】 https://www.bilibili.com/video/BV1pK41137He/?p=47&share_source=copy_web&vd_source=fce337a51d11a67781404c67ec0b5084
- 【Getting started with ASP.NET Core 6 · NLog/NLog Wiki (github.com)】 https://github.com/NLog/NLog/wiki/Getting-started-with-ASP.NET-Core-6
- 【NLog官方文档】https://nlog-project.org/config/
每日一道面试题
C#中的委托是什么?事件是不是一种委托?
答 : 委托可以把一个方法作为参数代入另一个方法,委托可以理解为指向一个函数的引用。事件是一种特殊的委托。
.NET 认识日志系统-2的更多相关文章
- C++ 高性能无锁日志系统
服务器编程中,日志系统需要满足几个条件 .高效,日志系统不应占用太多资源 .简洁,为了一个简单的日志功能引入大量第三方代码未必值得 .线程安全,服务器中各个线程都能同时写出日志 .轮替,服务器不出故障 ...
- Atitit.日志系统slf4j的使用
Atitit.日志系统slf4j的使用 SLF4J: Class path contains multiple SLF4J bindings. SLF4J: Found binding in [jar ...
- Android源码——Logger日志系统
Android的Logger日志系统是基于内核中的Logger日志驱动程序实现的. 日志保存在内核空间中 缓冲区保存日志 分类方法:日志的类型 + 日志的输出量 日志类型: main ...
- 使用Slf4j集成Log4j2构建项目日志系统的完美解决方案
一.背景 最近因为公司项目性能需要,我们考虑把以前基于的log4j的日志系统重构成基于Slf4j和log4j2的日志系统,因为,使用slf4j可以很好的保证我们的日志系统具有良好的兼容性,兼容当前常见 ...
- 日志系统实战(三)-分布式跟踪的Net实现
介绍 在大型系统开发调试中,跨系统之间联调开始变得不好使了.莫名其妙一个错误爆出来了,日志虽然有记录,但到底是哪里出问题了呢? 是Ios端参数传的不对?还是A系统或B系统提供的接口导致?相信有不少人遇 ...
- 日志系统实战(一)—AOP静态注入
背景 近期在写日志系统,需要在运行时在函数内注入日志记录,并附带函数信息,这时就想到用Aop注入的方式. AOP分动态注入和静态注入两种注入的方式. 动态注入方式 利用Remoting的Context ...
- Android性能优化之UncaughtExceptionHandler定制自己的错误日志系统
前言: 每当我们app测试的时候,测试人员总是对我们说这里崩溃了,那里挂掉了!我们只能默默接受,然后尝试着重现bug,更可悲的是有时候bug很难复现,为了解决这种现状所以我们要尝试这建立一个自己的bu ...
- [Asp.net 5] Logging-其他日志系统的实现
Microsoft.Framework.Logging.NLog 使用Nlog扩展日志系统:按照我们上节说的,对于扩展的日志系统都要实现俩个接口ILogger.ILoggerProvider.所以在当 ...
- 【转载】scribe、chukwa、kafka、flume日志系统对比
原文地址:http://www.ttlsa.com/log-system/scribe-chukwa-kafka-flume-log-system-contrast/ 1. 背景介绍许多公司的平台每天 ...
- Java日志系统及框架分析
最近在考虑将容器(Tomcat)内的应用日志统一成slf4j + logback,主要目的有: 快速定位应用日志输出路径,方便日志的采集: 能动态调整日志的级别,方便线上问题定位: 方便在容器层面做扩 ...
随机推荐
- 一文搞懂drag&drop浏览器拖放功能的实现
拖放功能,即将一个元素从一个区域,通过拖拽,放置到另一个区域.常见的应用是将文件或图片从一个区域,拖放到另一个区域.中文常常把这表述成拖拽,实际上拖拽的描述并不准确,应该叫拖放,因为drag事件和dr ...
- 微信小程序关于小说类使用官方阅读器
https://doc.weixin.qq.com/doc/w3_AAcAYAbdAFwpM63n1R5SIat3aa4cX?scode=AJEAIQdfAAoYHVCBbdAG4A1QYmAFQ 上 ...
- 阿里DataX极简教程
目录 简介 工作流程 核心架构 核心模块介绍 DataX调度流程 支持的数据 实践 下载 环境 执行流程 引用 简介 DataX是一个数据同步工具,可以将数据从一个地方读取出来并以极快的速度写入另外一 ...
- WPF登录界面样例
XAML文件内容如下 1 <Window x:Class="ERP.Views.Login" 2 xmlns="http://schemas.microsoft.c ...
- Swoole 源码分析之 Coroutine 协程模块
首发原文链接:Swoole 源码分析之 Coroutine 协程模块 大家好,我是码农先森. 引言 协程又称轻量级线程,但与线程不同的是:协程是用户级线程,不需要操作系统参与.由用户显式控制,可以在需 ...
- Python闭包和装饰器原理
# Python闭包和装饰器 ############# 闭包 ############## ''' 1. 一个外层函数,内嵌一个内层函数: 2. 内层函数使用外层函数的参数: 3. 外层函数将内层函 ...
- 使用 TestContainers 进行数据库集成测试
在软件开发过程中,集成测试是至关重要的一环.它确保不同组件之间的协作正常,并验证系统在整体上的功能和性能.然而,传统的集成测试往往需要依赖于外部资源,如数据库.消息队列等,这给测试环境的搭建和维护带来 ...
- 《最新出炉》系列入门篇-Python+Playwright自动化测试-50-滚动条操作
1.简介 有些页面的内容不是打开页面时直接加载的,需要我们滚动页面,直到页面的位置显示在屏幕上时,才会去请求服务器,加载相关的内容,这就是我们常说的懒加载.还有就是在日常工作和学习中,经常会遇到我们的 ...
- OpenCV笔记(5) Rect类
看项目代码时,发现了Rect的神奇用法,rect = rect + point.于是了解了一下Rect类. 1. 构造函数 public Rect(Point location, Size size) ...
- 很多人讲不明白HTTPS,但是我能
很多人讲不明白HTTPS,但是我能 今天我们用问答的形式,来彻底弄明白HTTPS的过程 下面的问题都是 小明和小丽两个人通信为例 可以把小明想象成服务端,小丽想象成客户端 1. https是做什么用的 ...