码迷,mamicode.com
首页 > 其他好文 > 详细

NLog 日志框架搭建讲解(亲测有效,代码齐全)

时间:2017-10-26 17:40:20      阅读:618      评论:0      收藏:0      [点我收藏+]

标签:layout   password   getc   manager   es2017   操作   target   插件   form   

前言:最近,搭建代码框架时,想要找一款日志框架。因为之前都是使用Log4net,所以这次打算使用一款新的NLog尝试下,感谢网上的这么多朋友发布的博文,对我有不少的启发作用。不过在对于写日志到数据库这一点,写对的为数不多,所以,我也记录下,算是个学习总结,也希望能帮助其他需要的童鞋。(本文不详细讲解NLog各参数,以及与Log4net的区别,大家可以到网上去搜,很多)

一、对项目添加NLog

选择自己想要添加的项目,使用Nuget添加NLog相关插件

技术分享

 

安装好后,项目里会引用 NLog.dll 和 NLog.config,NLog.xsd

 

二、对NLog.config进行配置

NLog.config默认仅给出地址,很少的配置,其余的需要我们自己进行填写

targets标签:是填写我们所需要的日志级别,里面有 Console,Debugger,File,Database,Mail 等

rules标签:targets标签要配合rules使用,rules指定了,每个日志所输出的目录地址

<targets>
    <target name="console" xsi:type ="Console" />
    <target name="debugger" xsi:type="Debugger" layout="${date:format=HH\:mm\:ss.fff}: ${message}" />
    <target name="error_file" 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}" />
    <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="database" xsi:type="Database" 
            connectionString ="Data Source=localhost;port=3306;Initial Catalog=Be_Log;user id=root;password=AllenLee;" 
            commandText="INSERT INTO t_user_log(user_id,user_name,action_type,user_ip,add_time,remark) Values(@user_id,@user_name,@action_type,@user_ip,@add_time, @remark);"
            >
      <parameter name = "@user_id" layout = "${event-context:item=user_id}"/>
      <parameter name = "@user_name" layout = "${event-context:item=user_name}" />
      <parameter name = "@action_type" layout = "${event-context:item=action_type}"/>
      <parameter name = "@user_ip" layout = "${event-context:item=user_ip}" />
      <parameter name = "@add_time" layout = "${event-context:item=add_time}" />
      <parameter name = "@remark" layout = "${event-context:item=remark}" />
      <dbProvider>MySql.Data.MySqlClient</dbProvider>
    </target>
    <!-- 发生致命错误发送邮件日志 -->
    <target name="email" xsi:type="Mail"
               header="-----header------"
               footer="-----footer-----"
               layout="${longdate} ${level} ${callsite} ${message} ${exception:format=Message, Type, ShortType, ToString, Method, StackTrace}"
               html="false"
               encoding="UTF-8"
               addNewLines="true"
               subject="${message}"
               to=""
               from=""
               body="${longdate} ${level} ${callsite} ${message} ${exception:format=Message, Type, ShortType, ToString, Method, StackTrace}"
               smtpUserName=""
               enableSsl="false"
               smtpPassword=""
               smtpAuthentication="Basic"
               smtpServer="smtp.163.com"
               smtpPort="25">
    </target>
</targets>

<rules>
<logger name="*" writeTo="console" />
<logger name="*" minlevel="Debug" writeTo="debugger" />
<logger name="*" minlevel="Error" writeTo="error_file" />
<logger name="*" level="Info" writeTo="info" />
<logger name="*" writeTo="database" />
</rules>

 

三、日志内容存储

有了以上配置,我们就可以写一处简单程序来进行测验,看是否能生成日志文件。

(1)日志文件生成(代码用的是MVC,大家可以随意用其他代码测试)

技术分享

 

通过这几个,可以把日志输入到文件,路径就在我们前面 target 所配置的里面

技术分享

 

打开一个具体文件查看,可见内容和我们程序写的是一样的:

技术分享

 

(2)日志写入数据库(注:此处是MySql,其他请各位自己尝试)

在MySql中,新建表 t_user_log 结构,与前面 target 中所列的字段相同,将连接字符串等写上。

注:<dbProvider>MySql.Data.MySqlClient</dbProvider>  这一个千万不要忘了

然后我们可以使用代码来进行测试:

private static readonly Logger Logger = LogManager.GetCurrentClassLogger();
LogEventInfo lei = new LogEventInfo();
lei.Properties["user_id"] = "18";
lei.Properties["user_name"] = "AllenLee";
lei.Properties["action_type"] = "Created Log";
lei.Properties["user_ip"] = "172.16.0.132";
lei.Properties["add_time"] = DateTime.Now;
lei.Properties["remark"] = "This is a remark";
lei.Level = LogLevel.Info;
Logger.Log(lei);

 

执行后,数据库表数据变化:

技术分享

 

可见数据能正常写入到数据库了,至此,无论是写文件,还是写数据库,NLog 都可以实现了。这样在项目里面操作起来就方便多了

大家如果有什么疑问,欢迎来讨论!

 

                                       

NLog 日志框架搭建讲解(亲测有效,代码齐全)

标签:layout   password   getc   manager   es2017   操作   target   插件   form   

原文地址:http://www.cnblogs.com/AllenLee/p/7737863.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!