NLog写入Mongo日志配置
Web网站中引入了NLog日志,日志记录在Mongo数据库中,经过两天的简单学习,现简要记录说明下:
首先贴出NLog的学习地址: https://github.com/NLog/NLog/wiki/Tutorial ,使用的NLog版本为:4.5+
以及此次项目中的NLog配置文档 :(NLog.Config)
<?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"> <extensions>
<add assembly="NLog.Mongo"/>
<add assembly="NLog.Web"/>
</extensions>
<targets>
<target xsi:type="Mongo"
name="mongoDefault"
connectionString="mongodb://192.168.106.56/MongoDB"
collectionName="SysErrorLog"
cappedCollectionSize="">
<field name="Date" layout="${longdate}"/>
<property name="RequestIP" layout="${aspnet-request-ip}" />
<property name="UserName" layout="$UserName" />
<property name="BaseDir" layout="${aspnet-appbasepath}"/>
<property name="QueryUrl" layout="${aspnet-request-url}"/>
<property name="Method" layout="${aspnet-request-method}"/>
<property name="Controller" layout="${aspnet-mvc-controller}"/>
<property name="Action" layout="${aspnet-mvc-action}" />
<property name="FormContent" layout="${aspnet-request-form}"/>
<property name="QueryContent" layout="${aspnet-request-querystring}"/>
</target>
</targets>
<rules>
<logger name="*" minlevel="Info" maxlevel="Fatal" writeTo="mongoDefault"/>
</rules>
</nlog>
相关节点的说明:
<target> 日志输出目标。目前NLog支持八十余种输出,如控制台,邮件,窗体,数据库等。具体支持的目标,可参考 这里 。一个<targets>中可以配置多个<target>输出。
1、target属性中标记了当前 target 的名称以及要输出到相关MongoDB的配置。
2、<field>指定 document中的根字段,name 对应的根节点名称,layout 对应输出值
3、<property> 指定 document中的properties节点中的子节点,name 对应的根节点名称,layout 对应输出值
4、不同的应用中,NLog能获取的系统参数可以看 这里 。
<rules> 指定 loger 的输出目标,即指定 logger 使用哪个 target 进行输出日志。本节配置指定最小级别为Info,最高级别为Fatal,并使用名称为 "mongoDefault" 的 target。
<extensions> NLog使用的扩展库。

由上边两个图知道,我们使用的MongoDB配置引用了 NLog.Mongo 动态库。layout中使用获取的 Web 参数使用了 NLog.Web动态库。不仅要在Nuget上获取这两个动态库,还应该在配置中引入。
关于日志中加入用户参数的使用说明:
public static void Error(Exception ex)
{
Logger logger = LogManager.GetCurrentClassLogger();
var UserName = Config.Identity?.Name ?? "";
var Target = ex.TargetSite.Name ?? "";
var parms = ex.Data?.ToDictionary().Select(k => k.Key + "=" + k.Value).Join() ?? "";
LogEventInfo theEvent = new LogEventInfo();
theEvent.Exception = ex;
theEvent.Message = ex.Message;
theEvent.Properties["Target"] = Target;
theEvent.Properties["Parameters"] = parms;
theEvent.Properties["UserName"] = UserName;
logger.Error(theEvent);
}
使用LogEventInfo写入自定义参数。本节中,将用户自定义的参数都放入到document的Properties节点中。
注:如果对应的节点值为空,则NLog不会写入该节点。
程序调用代码:
try
{
throw new DivideByZeroException("Opps");
}
catch (Exception e)
{
e.Data.Add(nameof(a),a);
e.Data.Add(nameof(b), b);
Error(e);
}
输入日志格式如下:
"_id" : ObjectId("5c8867288d14af392479e58f"),
"Date" : "2019-03-13 10:12:56.5343",
"Level" : "Error",
"Logger" : "Test.Web.Window.LogHelper",
"Message" : "Opps",
"Exception" : {
"Message" : "Opps",
"BaseMessage" : "Opps",
"Text" : "System.DivideByZeroException: Opps\r\n 在 Test.Web.Window.Controllers.TestController.Divid(Double a, Double b) 位置 D:\\Projects\\Common\\Test.Web\\Test.Web\\Test.Web.Window\\Controllers\\TestController.cs:行号 35",
"Type" : "System.DivideByZeroException",
"HResult" : -,
"Source" : "Test.Web.Window",
"MethodName" : "Divid",
"ModuleName" : "Test.Web.Window",
"ModuleVersion" : "1.0.0.0"
},
"Properties" : {
"RequestIP" : "::1",
"UserName" : "admin",
"BaseDir" : "D:\\Projects\\Common\\Test.Web\\Test.Web\\Test.Web.Window\\",
"QueryUrl" : "http://localhost/test/index",
"Method" : "GET",
"Controller" : "test",
"Action" : "index",
"Target" : "Divid",
"Parameters" : "a=5,b=0"
}
NLog写入Mongo日志配置的更多相关文章
- NLog文章系列——如何配置NLog(转)
NLog使用方法 作者:Jaros?aw Kowalski <> 翻译:CrazyCoder(由衷感谢他的热心!!) 原文:http://www.nlog-project.org/conf ...
- NLog文章系列——如何配置NLog
NLog支持以多种不同方式配置,目前同时支持直接编程和使用配置文件两种方法.本文将对目前支持的各种配置方式作详细描述. 日志配置 通过在启动的时候对一些常用目录的扫描,NLog会尝试使用找到的配置信息 ...
- Haproxy日志配置
haproxy在默认情况不会记录日志,除了在haproxy.conf中的global段指定日志的输出外,还需要配置系统日志的配置文件.下面以centos6.4为例,haproxy使用系统自带的rpm报 ...
- LOG4NET日志配置及使用
Log4net的安装 Install-Package log4net 1.先弄个日志记录的类 /// <summary> /// 使用LOG4NET记录日志的功能,在WEB.CONFIG里 ...
- Apache日志配置参数详细说明
Apache日志按时间分段记录 在apache的配置文件httpd.conf中找到ErrorLog logs/error_log及CustomLog logs/access_log common Li ...
- Apache日志配置详解(rotatelogs LogFormat)
logs/error_logCustomLog logs/access_log common--默认为以上部分 修改为如下: ErrorLog "|/usr/sbin/rotatelogs ...
- nginx日志配置
nginx日志配置 http://www.ttlsa.com/linux/the-nginx-log-configuration/ 日志对于统计排错来说非常有利的.本文总结了nginx日志相关的配置如 ...
- Nginx日志配置及日志切割
日志配置 日志对于统计排错来说非常有利的.本文总结了nginx日志相关的配置如access_log.log_format.open_log_file_cache.log_not_found.log_s ...
- 支持异步写入的日志类,支持Framework2.0
因为工作需要需要在XP上运行一个C#编写的Winform插件,我就用Framework2.0,因为存在接口交互所以想保留交易过程的入参出参. 考虑到插件本身实施的因素,就没有使用Log4.NLog等成 ...
随机推荐
- css揭秘
一:渐变 线性渐变(Linear Gradients)- 向下/向上/向左/向右/对角方向 background: linear-gradient(direction, color-sto ...
- Rails中activeAdmin的使用
一.开始ActiveAdmin Active Admin是一个发布在RAILS3中使用的Gem. 1.我们为了快速开始我们对Active Admin的了解,我们首先安装它: 在你GemFile中添加g ...
- [CQOI 2018]交错序列
Description 题库链接 定义长度为 \(n\) 的"交错序列"为:长度为 \(n\) 序列中仅含 \(0,1\) 且没有相邻的 \(1\) .给出 \(a,b\) ,假设 ...
- Linux多线程 - 基本操作
0. 线程 vs 进程 何为线程?线程即轻量级进程,如何理解轻量级这个概念? 我们知道,Linux的资源分为用户空间资源和内核空间资源: 用户空间资源:用来存放用户自定义的一些数据,用户可直接控制: ...
- Ionic CLI 升级到最新版本
由于Ionic 自身也在不停的更新当中, 所以开发者经常会遇到从官方的CLI 命令,在命令行窗口中执行出错的情况. 就比如我一个月之前安装的ionic 2.2.2版本,已不能使用最新的3.2.0 CL ...
- wcf读写cookie
一般来说,web应用的服务端(aspx或mvc的action)调用wcf时,是一个服务与服务的通讯,而不是客户端(浏览器)与服务器的通讯. 这种情况下,如果要在wcf端处理客户端的cookie,就需要 ...
- 数据库状态标识位flag设计
设计目的 减少各种状态值字段 减少数据库冗余和存储空间 增加状态值时可灵活调整,无需增加额外字段 运用场景 例子1:管理用户的支付方式 比如针对不同用户组设置了不同的支付方式支持,假设支付方式有支付宝 ...
- 《码出高效 Java开发手册》第一章计算机基础(未整理)
码云地址: https://gitee.com/forxiaoming/JavaBaseCode/tree/master/EasyCoding
- Java虚拟机_运行时数据区
Java虚拟机在执行Java程序的过程中会把它所管理的内存划分为若干个不同的数据区域. 这些区域都有各自的用途.各自的创建和销毁的时间,有的区域随着虚拟机进程的启动而存在,有些区域则是依赖用户线程启动 ...
- 资源在Windows编程中的应用
学习目的 掌握菜单和对话框资源的创建和使用. 编写程序: 设计一个窗口应用程序, 其中有一个VC菜单, 该菜单下有"显示", "隐藏", "退出&qu ...
