声明
private Logger _Logger = NLog.LogManager.GetCurrentClassLogger();
自定义属性
按模块名称创建日志文件夹
LogEventInfo logEvent = new LogEventInfo(LogLevel.Debug, _Logger.Name, message);
//自定义属性"ModularName"
logEvent.Properties["ModularName"] = param.ModuleName;
_Logger.Log(logEvent);
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">
<targets>
<target xsi:type="File"
name="f"
fileName="${basedir}/logs/${event-properties:item=ModularName}/${shortdate}.log"
encoding="UTP-8"
archiveAboveSize="102400"
layout="${longdate} ${uppercase:${level}} ${message}" />
</targets>
<rules>
<logger name="*" minlevel="Debug" writeTo="f" />
</rules>
</nlog>