首页 > 解决方案 > 从 App.Config 设置中引用 NLog 变量

问题描述

<envSettings>
    <environment name="Local">      
      <add key="ElasticSearch.Url" value="http://localhost:9200/" />
    </environment>
    <environment name="Dev">     
      <add key="ElasticSearch.Url" value="http://XXXXXXX:9200/" /> 
    </environment>
 </envSettings>

 <nlog autoReload="true" xmlns="http://www.nlog-project.org/schemas/NLog.xsd" 
      xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
      throwExceptions="false">
    <variable name="elastic.url" value="${envSettings:name=ElasticSearch.Url}"/> </nlog>

NLog 是否可以从 EnvSettings 读取值?我使用了 NLog.Extended nuget 包。

标签: c#.netapp-confignlog

解决方案


正如 Rolf 注意到的那样,您可能需要一个自定义布局渲染器,因为最接近的东西读取 System.Environment(例如${environment:variable=PATH}

那么代码:

// register ${ElasticSearch-Url}
LayoutRenderer.Register("ElasticSearch-Url", (logEvent) => retrieve ElasticSearch.url here);

尽快执行此操作,例如 inmain()app_start


推荐阅读