.NET_NLog

server/2024/9/24 10:18:36/

步骤

1. 添加依赖

①Microsoft.Extensions.DependencyInjection

②NLog.Extensions.Logging(或Microsoft.Extensions.Logging.___)

Tutorial · NLog/NLog Wiki · GitHub

2.添加nlog.config文件(默认名称, 可改为其他名称, 但需要另行配置)

文件的基础格式可从此处获取: Tutorial · NLog/NLog Wiki · GitHubNLog - Advanced and Structured Logging for Various .NET Platforms - Tutorial · NLog/NLog Wikiicon-default.png?t=N7T8https://github.com/NLog/NLog/wiki/Tutorial#configure-nlog-targets-for-output格式参考(关于config文件的说明在注释部分):

<?xml version="1.0" encoding="utf-8" ?>
<!-- XSD manual extracted from package NLog.Schema: https://www.nuget.org/packages/NLog.Schema-->
<nlog xmlns="http://www.nlog-project.org/schemas/NLog.xsd" xsi:schemaLocation="NLog NLog.xsd"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"autoReload="true"internalLogFile="logs/console-example-internal.log"internalLogLevel="Info" ><!-- the targets to write to --><targets><!-- write logs to file --><!-- archiveAboveSize: 日志文件的最大体积(字节数)|maxArchiveFiles: 日志文件的最大数量|maxArchiveDays: 日志文件的最大天数 --><target xsi:type="File" name="logfile" fileName="logs/console-example.log"layout="${longdate}|${level}|${message} |${all-event-properties} ${exception:format=tostring}" /><target xsi:type="Console" name="logconsole"layout="${longdate}|${level}|${message} |${all-event-properties} ${exception:format=tostring}" /></targets><!-- rules to map from logger name to target --><rules><!-- 从上至下依次匹配 --><!-- name: 匹配规则(类名)|minlevel: 最小日志输出等级|maxlevel: 最大日志输出等级|writeTo: 日志输出文件|final=true: 若匹配成功则不再向下匹配 --><logger name="*" minlevel="Trace" writeTo="logfile,logconsole"/></rules>
</nlog>

3.将nlog.config文件设置为"始终复制"或在项目设置页中将"Never"改为"Always"

示例

Program.cs

internal class Program
{static void Main(string[] args){ServiceCollection services = new();services.AddLogging(logBuilder=> {//logBuilder.AddConsole();                    // Microsoft.Extensions.Logging//logBuilder.SetMinimumLevel(LogLevel.Debug); // Microsoft.Extensions.LogginglogBuilder.AddNLog();});services.AddScoped<Example_1>();using ServiceProvider serviceProvider = services.BuildServiceProvider();Example_1 example_1 = serviceProvider.GetRequiredService<Example_1>();example_1.Start();}
}

Example_1.cs

internal class Example_1
{ILogger<Example_1> logger;public Example_1(ILogger<Example_1> logger){this.logger = logger;}public void Start(){logger.LogDebug("运行中...");try{File.ReadAllText("A:\\text.txt");logger.LogDebug("文件读取成功");}catch (Exception e){logger.LogError(e, "发生错误");}logger.LogDebug("结束");}
}

运行效果


http://www.ppmy.cn/server/38190.html

相关文章

【C++】:模板初阶

目录 一&#xff0c;泛型编程二&#xff0c;函数模板2.1 函数模板概念2.2 函数模板格式2.3 函数模板的原理2.4 函数模板的实例化2.5 模板参数的匹配原则 三&#xff0c;类模板3.1 类模板的定义格式3.2 类模板的实例化 一&#xff0c;泛型编程 在C语言中如何实现一个通用的交换…

【学习笔记】HarmonyOS 4.0 鸿蒙Next 应用开发--安装开发环境

开发前的准备 首先先到官网去下载Devco Studio 这个开发工具&#xff0c;https://developer.harmonyos.com/cn/develop/deveco-studio/#download 提供了WIndows和Mac的开发环境&#xff0c;我自己是Windows的开发环境。 所以下载之后直接点击exe进行安装即可。 如果之前安装过…

[力扣题解]150. 逆波兰表达式求值

题目&#xff1a;150. 逆波兰表达式求值 思路 建一个栈&#xff0c;遍历算式&#xff0c;遇到数字塞进去&#xff0c;遇到算符&#xff0c;去除栈顶2个元素进行运算&#xff1b; 假设算式是9 3 -&#xff0c;栈里的顺序是9 3&#xff0c;&#xff08;栈顶在右&#xff09;&am…

ChatGPT-Next-Web漏洞利用分析(CVE-2023-49785)

1. 漏洞介绍 ​ 日常网上冲浪&#xff0c;突然粗看以为是有关Chat-GPT的CVE披露出来了&#xff0c;但是仔细一看原来是ChatGPT-Next-Web的漏洞。漏洞描述大致如下&#xff1a;&#xff08;如果有自己搭建了还没更新的速速修复升级防止被人利用&#xff0c;2.11.3已经出来了&am…

HTTPS | HTTPS的证书和私钥文件如何进行匹配度比对?

关注WX&#xff1a;CodingTechWork 引言 在互联网通信中&#xff0c;保障数据传输的安全性至关重要。HTTPS&#xff08;Hypertext Transfer Protocol Secure&#xff09;是一种安全的HTTP协议&#xff0c;通过使用SSL/TLS协议进行加密来保护数据的传输。  在搭建HTTPS连接时…

社交客户关系管理(SCRM),和传统CRM的区分

一、SCRM是什么 SCRM是社交客户关系管理&#xff08;Social Customer Relationship Management&#xff09;的缩写&#xff0c;是指通过利用社交媒体和社交网络来管理和建立与客户之间的关系。SCRM将传统的客户关系管理&#xff08;CRM&#xff09;与社交媒体的互动和数据整合…

Saga事务实现原理详解与Java实践

引言 在分布式系统中&#xff0c;事务的ACID特性&#xff08;原子性、一致性、隔离性、持久性&#xff09;面临着巨大的挑战。传统的关系型数据库事务在分布式场景下往往难以适用&#xff0c;因此&#xff0c;各种分布式事务解决方案应运而生。其中&#xff0c;Saga模式作为一…

Mysql总结

推荐你阅读 互联网大厂万字专题总结 Redis总结 JUC总结 操作系统总结 JVM总结 Mysql总结 互联网大厂常考知识点 什么是系统调用 CPU底层锁指令有哪些 AQS与ReentrantLock原理 旁路策略缓存一致性 Java通配符看这一篇就够 基础篇 Mysql 的一条语句是如何执行的 Server 层是上层…