I’m building a web based hybrid system that can run on-premises and on cloud. On development machine I want NLog to write logs on disk. When system is deployed to cloud I want NLog to write logs to Windows Azure Table storage. In this posting I will show you how to use web.config transforms with NLog configuration.
For NLog running under web application the first place to look for configuration is web.config file. Starting from Visual Studio 2010 web.config files have support for transforms so you have root web.config and then child configuration files that inherit all settings in root. Those child configuration files may define transforms that modify settings inherited from root file. We are using this mechanism in this hybrid system.
NLog configuration
As with other custom configurations we need configuration section definition in web.config for NLog:
<section name=“nlog“ type=“NLog.Config.ConfigSectionHandler, NLog“/>
After configuration sections definition we add configuration block for NLog:
autoReload=“true“
throwExceptions=“true“>
<variable name=“appName“ value=“YourAppName“ />
<extensions>
<add assembly=“Minirent.SaaS.Azure“ />
</extensions>
<targets async=“true“>
<target type=“File“
name=“default“
layout=“${longdate} – ${level:uppercase=true}: ${message}${onexception:${newline}EXCEPTION\: ${exception:format=ToString}}“
fileName=“${basedir}\logs\\Debug.${shortdate}.log“
keepFileOpen=“false“
archiveFileName=“${basedir}\logs\\Debug_${shortdate}.{##}.log“
archiveNumbering=“Sequence“
archiveEvery=“Day“
maxArchiveFiles=“30“
/>
</targets>
<rules>
<logger name=“*“ writeTo=“default“ minlevel=“Info“ />
</rules>
</nlog>
NB! Don’t use xmlns and other namespace declarations for NLog. If you use then during transformation something gets messed up and all attributes with no namespace prefix get automatically generated prefix. It may be okay for transformation engine but it is not for NLog that is not able to understand XML like this.
By default, as you can see, I’m using file logger. It works also on cloud but these logs will be lost when Windows Azure replaces virtual machine where system is deployed.
Adding configuration for cloud
For Windows Azure we are using NLog target that writes log entries to Windows Azure Table Storage. This way we can use multiple instances of virtual machines and we can be sure that logs are not deleted when virtual machine is replaced.
For Windows Azure we use release config. This is child configuration file called. Web.Release.config. In this file we replace the whole NLog configuration block with Windows Azure one.
<nlog
autoReload=“true“
throwExceptions=“true“ xdt:Transform=“Replace“>
<variable name=“appName“ value=“YourAppName“ />
<extensions>
<add assembly=“Minirent.SaaS.Azure“ />
</extensions>
<targets async=“true“>
<target type=“AzureStorage“ name=“azure“ tableStorageConnectionStringName=“StorageConnectionString“ />
</targets>
<rules>
<logger name=“*“ writeTo=“azure“ minlevel=“Info“ />
</rules>
</nlog>
You can see here Replace-transform used (xdt:Transform attribute of root node). When we make deployment to Windows Azure then release configuration is used and original NLog block in web.config is replaced by one shown here.
View Comments (2)
Thanks!.. I missed the '' part... :-)
I really don't want to put nlog configuration inside web.config. It is much better when it is in a separate nlog.config, so the logging configuration can be tweaked without forcing the app to be reloaded.