分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 前端开发

.NET Core 使用NLog日志记录

发布时间:2023-09-06 02:07责任编辑:赖小花关键词:.NET

前言

每个项目都会需要使用到日志功能,这对于项目上线后 出现的bug异常,能及时定位和便于后期错误分析。那我们今天来看看在.NET Core中如何使用NLog日志。

NLog

什么是NLog呢?

NLog是一个基于.NET平台编写的类库,我们可以使用NLog在应用程序中添加极为完善的跟踪调试代码。
NLog是一个简单灵活的.NET日志记录类库。通过使用NLog,我们可以在任何一种.NET语言中输出带有上下文的(contextual information)调试诊断信息,根据喜好配置其表现样式之后发送到一个或多个输出目标(target)中。
NLog的API非常类似于log4net,且配置方式非常简单。NLog使用路由表(routing table)进行配置,这样就让NLog的配置文件非常容易阅读,并便于今后维护。
NLog遵从BSD license,即允许商业应用且完全开放源代码。任何人都可以免费使用并对其进行测试,然后通过邮件列表反馈问题以及建议。
NLog支持.NET、C/C++以及COM interop API,因此我们的程序、组件、包括用C++/COM 编写的遗留模块都可以通过同一个路由引擎将信息发送至NLog中。
简单来说Nlog就是用来记录项目日志的组件

使用步骤

①在NuGet中安装:NLog.Config和 NLog.Extensions.Logging

②配置Configure如下

 public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory){ ??? loggerFactory.AddNLog();//添加NLog}

③打开项目bin/debug目录,找到

④将里面内容替换成:

<?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" ?????autoReload="true" ?????internalLogLevel="Warn" ?????internalLogFile="internal-nlog.txt"> ??<!--define various log targets--> ?<targets> ????<!--write logs to file--> ???<target xsi:type="File" name="allfile" fileName="nlog-all-${shortdate}.log" ????????????????layout="${longdate}|${logger}|${uppercase:${level}}|${message} ${exception}" /> ????<target xsi:type="File" name="ownFile-web" fileName="nlog-my-${shortdate}.log" ????????????????layout="${longdate}|${logger}|${uppercase:${level}}|${message} ${exception}" /> ????<target xsi:type="Null" name="blackhole" /> ??</targets> ??<rules> ???<!--All logs, including from Microsoft--> ???<logger name="*" minlevel="Trace" writeTo="allfile" /> ????<!--Skip Microsoft logs and so log only own logs--> ???<logger name="Microsoft.*" minlevel="Trace" writeTo="blackhole" final="true" /> ???<logger name="*" minlevel="Trace" writeTo="ownFile-web" /> ?</rules> </nlog>

⑤在HomeController中添加DI注入

 private readonly ILogger<HomeController> _logger; public HomeController(ILogger<HomeController> logger) ???{ ???????????_logger = logger; ???}

⑥测试效果

_logger.LogError("我是错误显示");_logger.LogDebug("我是调试信息"); _logger.LogInformation("我是提示信息");

执行后,查看bin/debug/netcoreapp2.0下面的nlog-my-2018-08-12.log文件即可看到输出日志:

关于Nlog日志的就先介绍到这儿,这只是一个基础入门讲解,更多内容可以参考:Nlog官网

.NET Core 使用NLog日志记录

原文地址:https://www.cnblogs.com/zhangxiaoyong/p/9463791.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved