前言

咱们上回讲到,.net core中内置的Logging日志框架的使用,以及浅显的讲解,接下来,给大家介绍一个第三方日志框架(NLog)。

NLog简介

NLog是适用于各种.NET平台(包括.NET标准)的灵活,免费的日志记录平台。NLog使写入多个目标变得容易 。(数据库,文件,控制台)并即时更改日志记录配置。

NLog的优势

  • NLog支持结构化 和传统日志记录。
  • NLog的重点是:高性能,易于使用,易于扩展和灵活配置。

1.NuGet安装NLog

NLog.Web.AspNetCore
NLog.Config

简短说明:

  • NLog.Web.AspNetCore:引入第三方的服务,可以在程序中使用
  • NLog.Config:安装之后,会自动生成一个配置文件模板(NLog.Config)。

2.引入服务(Program)

  public class Program
{
public static void Main(string[] args)
{
//添加Nlog的配置项
NLogBuilder.ConfigureNLog("NLog.config");
CreateHostBuilder(args).Build().Run();
} public static IHostBuilder CreateHostBuilder(string[] args) =>
Host.CreateDefaultBuilder(args)
.ConfigureLogging(log => {
//从builder移除内置的日志框架(如果引用第三方,一定要设置这属性)
log.ClearProviders();
//将日志添加到控制台
log.AddConsole();
//将日志添加到Debug窗口
log.AddDebug();
})
.ConfigureWebHostDefaults(webBuilder =>
{
webBuilder.UseStartup<Startup>();
}).
UseNLog();//引用第三方日志框架
}

需要注意的几个地方:

  • NLogBuilder.ConfigureNLog("NLog.config");引入配置文件
  • log.ClearProviders();移除内置的日志框架(Logging)
  • log.AddConsole();将日志添加到控制台
  • log.AddDebug();将日志添加到debug窗口
  • UseNLog()在末尾引入第三方的日志框架(一定要写

3.修改NLog.Config文件

简单介绍配置文件中的配置信息

+ xmlns,xsi是引入命名空间
+ autoReload="true"是热更新,在程序运行过程中也可以修改配置文件
+ throwExceptions:NLog日志系统抛出异常
+ internalLogLevel:日志级别
+ internalLogFile:内部日志文件
+ variable:定义变量
+ targets:日志输出地方
+ rules:日志的路由规则

3.1日志显示控制台版本

<?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"
xsi:schemaLocation="http://www.nlog-project.org/schemas/NLog.xsd NLog.xsd"
autoReload="true"
throwExceptions="false"
internalLogLevel="Off" internalLogFile="c:\temp\nlog-internal.log">
<variable name="myvar" value="myvalue"/> <targets>
<!--使用可自定义的着色将日志消息写入控制台-->
<target name="colorConsole" xsi:type="ColoredConsole" layout="[${date:format=HH\:mm\:ss}]:${message} ${exception:format=message}" />
</targets> <rules>
<logger name="*" minlevel="Warn" writeTo="colorConsole" />
</rules>
</nlog>

效果如下:

3.2日志存入本地txt版本

需要注意的地方

target中的参数

  • name:是指的输出地方的一个名词(给rules调用的)
  • xsi:type:输出文件的类型,File指的是文件
  • fileName:输出到目标文件的地址,使用的相对路径,可以自行配置输出的地点。
  • layout:在最简单的形式中,布局是带有嵌入标记的文本,这些嵌入标记由${和分隔}
  • archiveFileName:表示滚动日志存放路径
  • archiveAboveSize:单次日志的存储大小(单位是KB),超过配置,会archiveFileName中创建新的日志
  • archiveNumbering:Sequence(排序),Rolling(滚动)
  • concurrentWrites:支持多个并发一起写文件,提高文件写入性能。
  • keepFileOpen:为了提高文件写入性能,避免每次写入文件都开关文件
  • autoFlush:为了提高日志写入性能,不必每次写入日志都直接写入到硬盘
  • createDirs:若设置的日志文件夹不存在,则自动创建文件夹。

rules中的参数

  • logger:代表一个路由的规则
  • name:logger名称,若为*则表示适用于所有日志
  • minlevel:表示当前日志的最低日志级别,只有等于或大于该值的日志级别才会被记录
  • writeTo:和target的name匹配,一个rules对应一个target
<?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"
xsi:schemaLocation="http://www.nlog-project.org/schemas/NLog.xsd NLog.xsd"
autoReload="true"
throwExceptions="false"
internalLogLevel="Off" internalLogFile="c:\temp\nlog-internal.log"> <!-- optional, add some variables
https://github.com/nlog/NLog/wiki/Configuration-file#variables
-->
<variable name="myvar" value="myvalue"/> <targets> <!--项目日志保存文件路径说明fileName="${basedir}/保存目录,以年月日的格式创建/${shortdate}/${记录器名称}-${单级记录}-${shortdate}.txt"-->
<target name="log_file" xsi:type="File"
fileName="${basedir}/Logs/${shortdate}/${logger}-${level}-${shortdate}.txt"
layout="${longdate} | ${message} ${onexception:${exception:format=message} ${newline} ${stacktrace} ${newline}"
archiveFileName="${basedir}/archives/${logger}-${level}-${shortdate}-{#####}.txt"
archiveAboveSize="1024"
archiveNumbering="Sequence"
concurrentWrites="true"
keepFileOpen="false"
autoFlush="false"
encoding="utf-8"
createDirs="true"
/>
<!--使用可自定义的着色将日志消息写入控制台-->
<target name="colorConsole" xsi:type="ColoredConsole" layout="[${date:format=HH\:mm\:ss}]:${message} ${exception:format=message}" />
</targets>
<rules>
<logger name="Microsoft.*" minlevel="Info" writeTo="log_file" final="true" />
<logger name="*" minlevel="Info" writeTo="log_file" />
<!--logger name="*" minlevel="Warn" writeTo="colorConsole" /-->
</rules>
</nlog>

效果如下



正如大家看到一样,是以日志的类型进行区分建立txt日志文档,这样不仅可以区分不同的日志级别,还可以根据不同的Controller生成对应的日志,在以后分析日志的问题的时候,可以精确到某一个点的日志问题。

3.3日志存入数据库版本

您可以将此目标与各种数据库提供程序一起使用,例如System.Data,Microsoft.Data,Oracle,MySql,SqlLite等,本文以SQL为例。

注意事项

  • 在.net core中使用Nlog,dbProvider需要设置说明(是什么数据库,在Nlog的官方文档有明确提示)
  • 根据不同的数据库,安装不同的驱动,本文使用的是SQL Server,所以需要在NuGet安装:Microsoft.Data.SqlClient
3.3.1需要创建数据库
CREATE TABLE [dbo].[NLog] (
[ID] [int] IDENTITY(1,1) NOT NULL,
[MachineName] [nvarchar](200) NULL,
[Logged] [datetime] NOT NULL,
[Level] [varchar](5) NOT NULL,
[Message] [nvarchar](max) NOT NULL,
[Logger] [nvarchar](300) NULL,
[Properties] [nvarchar](max) NULL,
[Callsite] [nvarchar](300) NULL,
[Exception] [nvarchar](max) NULL,
CONSTRAINT [PK_dbo.Log] PRIMARY KEY CLUSTERED ([ID] ASC)
WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
)
3.3.2配置Nlog
<?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"
xsi:schemaLocation="http://www.nlog-project.org/schemas/NLog.xsd NLog.xsd"
autoReload="true"
throwExceptions="false"
internalLogLevel="Off" internalLogFile="c:\temp\nlog-internal.log"> <!-- optional, add some variables
https://github.com/nlog/NLog/wiki/Configuration-file#variables
-->
<variable name="myvar" value="myvalue"/> <targets>
<!--存储数据库-->
<target name="apiUsageLog"
xsi:type="Database"
dbProvider="Microsoft.Data.SqlClient.SqlConnection,Microsoft.Data.SqlClient"
connectionString="Data Source=.;Initial Catalog=test;User ID=sa;Password=123456;">
<commandText>
INSERT INTO [dbo].[NLog] (
[MachineName],
[Logged],
[Level],
[Message],
[Logger],
[Properties],
[Callsite],
[Exception]
) VALUES (
@machineName,
@logged,
@level,
@message,
@logger,
@properties,
@callsite,
@exception
);
</commandText>
<parameter name="@machineName" layout="${machinename}" />
<parameter name="@logged" layout="${date}" />
<parameter name="@level" layout="${level}" />
<parameter name="@message" layout="${message}" />
<parameter name="@logger" layout="${logger}" />
<parameter name="@properties" layout="${all-event-properties:separator=|}" />
<parameter name="@callsite" layout="${callsite}" />
<parameter name="@exception" layout="${exception:tostring}" />
</target>
</targets> <rules>
<logger name="*" minlevel="Trace" writeTo="apiUsageLog" />
</rules>
</nlog>
3.3.3如何使用?
        //获取Nlog对象
private Logger _logger = LogManager.GetCurrentClassLogger();
public void Get()
{
_logger.Info("asd");
_logger.Debug("测试消息Debug");
_logger.Warn("测试消息Warn");
_logger.Trace("测试消息Trace");
_logger.Error("测试消息Error");
}
3.3.4实际效果

3.4邮箱发送日志版本

这个比较简单,只需要简单配置即可

<?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"
xsi:schemaLocation="http://www.nlog-project.org/schemas/NLog.xsd NLog.xsd"
autoReload="true"
throwExceptions="false"
internalLogLevel="Off" internalLogFile="c:\temp\nlog-internal.log"> <!-- optional, add some variables
https://github.com/nlog/NLog/wiki/Configuration-file#variables
-->
<variable name="myvar" value="myvalue"/> <targets>
<!--邮箱-->
<target xsi:type="Mail"
name="emial"
header="=============================================="
footer="=============================================="
html="true"
addNewLines="true"
encoding="UTF-8"
subject="测试日志信息${machinename}"
body="${newline}${message}${newline}"
enableSsl="true"
to="接受邮件的邮箱地址"
from="发送邮件的邮箱地址"
smtpPassword="发送邮件的邮箱密码"
smtpAuthentication="Basic"
smtpServer="smtp.163.com"
smtpPort="25"
smtpUserName="发送邮件的邮箱地址">
</target>
</targets> <rules>
<logger name="*" minlevel="Trace" writeTo="emial" />
</rules>
</nlog>

效果如下图:

4.总结

想比较Logging日志框架,NLog的好处就不必多说,多样的存储方式,简洁明了的配置信息,在项目中使用,来给我带来很好的分析问题的好帮手,日志类型还可以分块,日志大小还能切割,极大的满足了我们的日常需求。需要注意一点,发邮件可以群发,需要配置,存数据库可以用存储过程,可以查看官方文档。

5.参考文档

Nlog官方文档

.net core中的那些常用的日志框架(NLog篇)的更多相关文章

  1. .net core中的那些常用的日志框架(Serilog篇)

    前言 上文说到Nlog日志框架,感觉它功能已经很强大,今天给大家介绍一个很不错的日志框架Serilog,根据我的了解,感觉它最大的优势是,结构化日志,它输出的日志是Json的格式,如果你使用的是Mon ...

  2. .net core中的那些常用的日志框架(Logging篇)

    前言 日志,在我们每个项目中是必不可少的,它不仅能在调试的时候测试数据,而且在项目上线,也是我们排查错误的得力助手,那我就能谈谈,用的多的几个日志框架吧!如果有不对的地方,欢迎来指教错误,谢谢! As ...

  3. 一个简单好用的日志框架NLog

    之前我介绍过如何使用log4net来记录日志,但最近喜欢上了另一个简单好用的日志框架NLog. 关于NLog和log4net的比较这里就不多讨论了,感兴趣的朋友可以参看.NET日志工具介绍和log4n ...

  4. Java常用的日志框架

    1.Java常用日志框架对比 https://www.jianshu.com/p/bbbdcb30bba8 2.Log4j,Log4j2,Logback日志框架性能对比 https://bbs.hua ...

  5. 来,带你鸟瞰 Java 中4款常用的并发框架!

    1. 为什么要写这篇文章 几年前 NoSQL 开始流行的时候,像其他团队一样,我们的团队也热衷于令人兴奋的新东西,并且计划替换一个应用程序的数据库. 但是,当深入实现细节时,我们想起了一位智者曾经说过 ...

  6. 日志框架 NLog

    这里按老规矩先进行和其它产品进行比较: 目前在.net平台存在两个比较老牌的日志框架分别为Log4net和NLog. 我们进行对这两种框架进行比较下 Log4net Log4net是一个老牌的日志框架 ...

  7. net core中动态给log4net添加日志类型

    private static object m_Lock = new object(); /// <summary> /// 根据类型获取对应的日志操作类 /// </summary ...

  8. JAVA中几种常用的RPC框架介绍

    原文:https://blog.csdn.net/zhaowen25/article/details/45443951

  9. 玩转ASP.NET Core中的日志组件

    简介 日志组件,作为程序员使用频率最高的组件,给程序员开发调试程序提供了必要的信息.ASP.NET Core中内置了一个通用日志接口ILogger,并实现了多种内置的日志提供器,例如 Console ...

随机推荐

  1. [BUUOJ记录] [GXYCTF2019]BabyUpload

    CTF三大骗局:Baby Easy Funny,本题主要考察.htaccess文件解析文件.文件类型检测绕过 打开题目给了一个上传点,上传一个php文件看看过滤规则 “后缀名不能有ph”直接禁掉了所有 ...

  2. Template DB MySQL学习总结

    Zabbix 5.0下如何应用Template DB MySQL来监控MySQL数据库呢?下面简单整理一下如何配置.应用Zabbix下自带的模板Template DB MySQL.其实非常简单. Te ...

  3. KMP - NOI2014 动物园

    单题分析:NOI2014 动物园. 题目分析:很明显题目已明确指出这是有关KMP的题,思考KMP.本题与普通KMP不同之处在于它求的是不相交最长相同前缀后缀. 如何处理不相交: 1.暴力     2. ...

  4. SpringBoot简单(登录/显示/登出)工程下载 附带打包成ROOT.war文件并发布到tomcat里

    下载地址:https://files.cnblogs.com/files/xiandedanteng/SessionShare20191226-1.zip 之前的工程仅能在Eclispe里跑起来,要把 ...

  5. 重学Ajax

    什么是Ajax Asynchronous JavaScript and xml 异步的JavaScript和XML 只是一种js的应用,在无需重新加载整个网页的情况下实现部分网页的数据更新的技术.减少 ...

  6. get_started_3dsctf_2016

    题外:这道题不是很难,但是却难住了我很久.主要是在IDA中查看反编译出的伪代码时双击了一下gets()函数,结果进入gets函数内部,我当时就懵了,误以为这是一个自定义函数,但是自定义函数应该应该不能 ...

  7. 乔悟空-CTF-i春秋-Web-SQLi

    2020.09.05 今天注定是高产的一天,这题真是坑,不看wp真的不会做,现在回头来复习一遍. 做题 题目 题目地址 做题 这题坑人的地方就在于重定向了两次,并且重要信息在第一次里藏着,第二次还给了 ...

  8. 阿里巴巴内部Java成长笔记,首次曝光!真的香!

    前言 关于技术人如何成长的问题,一直以来都备受关注,因为程序员职业发展很快,即使是相同起点的人,经过几年的工作或学习,会迅速拉开极大的差距,所以技术人保持学习,提升自己,才能够扛得住不断上赶的后浪,也 ...

  9. 口罩预约管理系统——系统网站实现(前端+PHP+MySQL)

    口罩预约管理系统网站实现 一.前言 二.系统登陆逻辑及界面实现 三.用户模块 1.用户预约系统界面 2.用户查看我的订单界面 3.用户修改预约信息 四.管理员模块 1.管理员登陆界面 2.查看用户预约 ...

  10. hw小技巧(转载)

    小弟也第一次参加hw,经过5天hw,确实也学到了许多的东西,但就本次分享而言,我分享一些我认为在hw里面值得注意的东西以及一些小技巧 0x01 信息收集 信息收集这个多西当然都是老生常谈了,你收集的东 ...