如何以编程方式配置nLog目标

时间:2018-03-22 15:09:20

标签: c# nlog

我试图弄清楚如何以编程方式配置具有两个电子邮件类型子目标的NLog FallbackGroup目标。基于应用程序启动期间发生的一些事情,我想覆盖FallbackGroup目标的两个子目标的“to”部分。

目前,该应用程序有一个NLog.config文件,其中包含这些目标。但是,这些值是硬编码的。任何更改都需要重新部署应用程序......这不是我们想要的......我们真正需要的是能够在启动时调用的某些逻辑中修改两个目标中的“to”设置。

这是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 name="logfile" xsi:type="File" fileName="BAM_logfile.txt" />
    <target xsi:type="FallbackGroup"
        name="email-error"
        returnToFirstOnSuccess="true">      
        <target xsi:type="Mail"
            name="mailserver1"
            to="kevin.orcutt@acme.com"
            from="noreply@acme.com"
            subject="Exception Message from: ${processname} v:${assembly-version} on ${machinename}"
            smtpServer="smtp.acme.com"
            smtpPort="25"
            layout="${longdate}${newline}${windows-identity} running ${processname} v:${assembly-version} on ${machinename}${newline}At: ${callsite}${newline}Message: ${message}${newline}Exception:${newline}${exception:format=toString,Data:maxInnerExceptionLevel=10}${newline}" />
        <target xsi:type="Mail"
            name="mailserver2"
            to="kevin.orcutt@acme.com"
            from="noreply@acme.com"
            subject="Exception Message from: ${processname} v:${assembly-version} on ${machinename}"
            smtpServer="mail.acme.com"
            smtpPort="25"
            layout="${longdate}${newline}${windows-identity} running ${processname} v:${assembly-version} on ${machinename}${newline}At: ${callsite}${newline}Message: ${message}${newline}Exception:${newline}${exception:format=toString,Data:maxInnerExceptionLevel=10}${newline}" />
    </target>
</targets>
<rules>
    <logger name="*" minlevel="Info" maxlevel="Warn" writeTo="logfile" />
    <logger name="*" level="Error" writeTo="email-error" />
</rules>
<extensions>
    <add assembly="NLog.MailKit"/>
</extensions>
</nlog>

所以我的问题是......有没有办法以编程方式覆盖NLog.config文件中的“to”部分子目标,或者最好在应用程序上配置整个FallbackGroup目标开始?第二个也是不太明显的问题是我正在寻找一些解决方案的例子......我还没有找到要做的代码...: - (

1 个答案:

答案 0 :(得分:2)

它的工作原理如下:

从相应的XML文件加载配置。这可以是您的app.config或单独的XML文件。然后按名称查找目标,并将其强制转换为适当的类型。从那里你可以修改它的属性,但你觉得合适。

var xmlConfig = new XmlLoggingConfiguration("nlog.config");
var target = xmlConfig.FindTargetByName("mailserver1") as MailTarget;
target.To = "...";

您可以对任何目标执行此操作:按名称加载,然后将其强制转换为适当的类型。当您完成更改后,请应用配置:

LogManager.Configuration = xmlConfig;

这应该在你获得任何记录器之前在启动时完成。我认为在应用这些更改之前,您获得的任何记录器都不会受到影响。