NLog简单配置与使用

摘要:
将NLog添加到项目的安装完成后,导入的dll将自动导入到项目中,并添加以下两个文件NLog配置,主要在配置文件中。NLog的配置文件主要包括三个节点:变量、目标和规则。变量节点用于定义一些变量-定义日志的目标/输出。较低级别是-定义日志的路由规则。较低级别是简单配置:这用于在控制台中输出日志信息。通常不配置以下两个。它们用于在文本文件中写入日志。fileName表示日志文件的路径,Layout表示日志的格式。

对项目添加NLog

NLog简单配置与使用第1张

NLog简单配置与使用第2张

安装完成后,在项目里面会自动引入该引入的dll,并且会添加如下两个文件

 NLog简单配置与使用第3张

NLog的配置主要是在这个config文件里。当然也可以将这个文件里面的nlog节点复制到项目配置文件App.config/Web.config里面。

 NLog的配置文件主要有3个节点variable,targets,rules。

variable节点用于定义一些变量

<targets /> - 定义日志的目标/输出,下级是<target>

<rules /> - 定义日志的路由规则,下级是<logger>
 
简单配置:
<target name="console" xsi:type ="Console" />   这个是用于在控制台中输出日志信息,一般不配置这个

 下面这两个是用于在文本文件里面写入日志,fileName表示日志文件的路径,layout表示日志的格式。大括号里面的变量是系统预定义的,

当然也可以在variable节点里面自定义

<target name="info" xsi:type="File"
fileName="${basedir}/Logs/Info/${shortdate}/info.txt"
maxArchiveFiles="30"
layout="${longdate} | ${level:uppercase=false} | ${message} ${onexception:${exception:format=tostring} ${newline} ${stacktrace} ${newline}" />
<target name="error" xsi:type="File"
fileName="${basedir}/Logs/Error/${shortdate}/error.txt"
maxArchiveFiles="30"
layout="${longdate} | ${level:uppercase=false} | ${message} ${onexception:${exception:format=tostring} ${newline} ${stacktrace} ${newline}" />

下面这个是将日志写入数据库的配置,这里配置的是SqlServer,当然还可以配置其他数据库

<target xsi:type="Database"
name="DatabaseFile"
dbProvider="System.Data.SqlClient"
commandText="Insert into ErrorLog(ID, Content, CreateTime) Values(@id, @content, @createTime);"
connectionString="data source=.;initial catalog=pay.log;user id=sa;password=sa;">
<parameter name="@id" layout = "${event-context:item=id}"/>
<parameter name="@content" layout = "${event-context:item=content}" />
<parameter name="@createTime" layout = "${date}"/>

结合上面的target节点,配置如下的路由节点,这些logger节点在rules节点下

<logger name="*" writeTo="DatabaseFile" />
<logger name="*" minlevel="Info" writeTo="info" />
<logger name="*" minlevel="Error" writeTo="error" />
<logger name="*" writeTo="console" />

代码中调用NLog:

public static void DBLog()
        {
            //log.Error("错误日志");
            //log.Info("信息日志");
       //log.Fatal("fatal日志"); LogEventInfo lei = new LogEventInfo(); lei.Properties.Add("id", Guid.NewGuid().ToString()); lei.Properties.Add("content", "sdfsd3222第三代2222"); //lei.Properties.Add("createTime", DateTime.Now); lei.Level = LogLevel.Info; log.Log(lei); }

上面注释的3行分别对应target节点里面name为error和info这两个节点配置,fatal的日志和error的日志写在了同一个文件里面。

还有一个统一的方法就是log.Log(LogLevel.Error, "错误2553");根据参数来确定日志的级别,但是这个方法要注意的是,如果参数是error,

那么会在info和error两个地方写入日志,但是只有info的时候,就只在info下有日志。

根据target的配置,调用函数后,日志文件在binReleaseLogs下

NLog简单配置与使用第4张

 后面的代码是将日志写入数据库的,对应的target节点是DatabaseFile。lei.Level这个属性必须设置,除了为LogLevel.Off外,其他的都可以

将日志写入数据库。要注意的是,在此之前确保数据库里面有相应的表。

免责声明:文章转载自《NLog简单配置与使用》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇「杂谈」苏州吴中区买房有哪些选项?(转)SVN分支/合并原理及最佳实践下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

Datax3.0使用说明

原文链接:https://github.com/alibaba/DataX/blob/master/introduction.md 一、datax3.0介绍 1、DataX 是一个异构数据源离线同步工具,致力于实现包括关系型数据库(MySQL、Oracle等)、HDFS、Hive、ODPS、HBase、FTP等各种异构数据源之间稳定高效的数据同步功能。 2...

使用kettle实现最基础的数据表同步

最近数据交换项目上需要用到ETL工具,原来一直不太了解,经同事介绍kettle可以很方便地进行数据同步。于是简单试用了一下,实现了从源表到目标表的数据同步(包括增删改)。 我们的需求如下:将业务系统指定表(source表)中的数据,同步到交换平台上相同结构的表(target表)中。不论source表中的数据新增、修改、删除,都会同步更新到target表中。...

IDEA异常 -- 汇总

目录 [TOC] Error:java: Compilation failed: internal java compiler error 解决办法: File-->Setting...-->Build,Execution,Deployment-->Compiler-->Java Compiler 设置相应Module的targ...

Flask-websocket实现聊天功能

群聊无昵称 原生js代码 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>群聊</title> </head> <body> <p> <...

Luci实现框架

1.总述 上一篇总结了uhttpd的工作方式,openwrt中利用它作为web服务器,实现客户端web页面配置功能。对于request处理方式,采用的是cgi,而所用的cgi程序就是luci,工作框架如下图所示: Client端和serv端采用cgi方式交互,uhttpd服务器的cgi方式中,fork出一个子进程,子进程利用execl替换为luci进...

Java 审计 之过滤器防御xss

Java 审计 之过滤器防御xss 0x00 前言 本文从攻击与防守两个角度来思考一些审计中的小细节。在前面两篇的xss审计中,写少了一个比较重要的点,就是Filter过滤器。都说Java的审计第一步就是先看web.xml,能看到该cms使用的是哪些框架来进行开发。其次就是看其有没有配置的一些过滤器。 审计文章: Java审计之XSS篇 Java 审计之x...