У меня есть служба Windows с app.config
и log4net.config
.
app.config
:
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
</configSections>
<log4net configSource="log4net.config" />
log4net.config
:
<log4net>
<appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender">
<param name="File" value="D:\Projects\Integration\Interface Module\bin\Logs\MyFirstLogger.log"/>
<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
<appendToFile value="true" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="2" />
<maximumFileSize value="1MB" />
<staticLogFileName value="true" />
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%d [%t] %-5p %c %m%n"/>
</layout>
</appender>
<root>
<level value="ALL" />
<appender-ref ref="LogFileAppender" />
</root>
</log4net>
Я также добавил это в AssemblyInfo.cs
:
[assembly: log4net.Config.XmlConfigurator(Watch = true)]
И на одном из моих занятий у меня есть:
private readonly ILog _log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
а также
_log.Info(content);
Я предоставил всем пользователям полные права доступа к моей папке журналов.
Моя папка bin (из которой работает служба) содержит как мои app.config
, так и log4net.config
.
Но файл журнала не был сгенерирован. Какие настройки я пропустил?
Обновлено 4 марта 2014 г.
Если вы используете отдельный файл конфигурации, как я (log4net.config), не забудьте установить для параметра Copy to output directory
значение Copy always
в обозревателе решений.
[assembly: log4net.Config.XmlConfigurator(Watch = true)]
и вызовLogManager.GetLogger
находятся в одной сборке? - person YK1   schedule 15.05.2013