Log4net在xml中使用相同的appender配置来记录多个文件
本文关键字:配置 appender 记录 文件 xml Log4net | 更新日期: 2023-09-27 18:19:44
我的配置中有这个appender:appender name="TC3DataLogger" type="Intel.STHI.Device.ContextLog.TC3DataLogger" >
<file value="null" />
<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
<appendToFile value="true" />
<rollingStyle value="Once" />
<maxSizeRollBackups value="10" />
<maximumFileSize value="100MB" />
<datePattern value="-yyyyMMdd-HHmm" />
<layout type="log4net.Layout.PatternLayout">
<header value="Date, CS, FeedbackInput, PWM_Duty_Cycle (Cold='-' Hot='+') "/>
<conversionPattern value="%date{yyyy-MM-dd HH:mm:ss}, %message%newline" />
</layout>
<filter type="log4net.Filter.LoggerMatchFilter">
<acceptOnMatch value="true" />
<LoggerToMatch value="Intel.STHI.Device.ContextLog.TC3DataLogger" />
</filter>
<filter type="log4net.Filter.DenyAllFilter" />
</appender>
我需要同时登录到多个文件。我以这种方式创建每个日志文件:
public void CreateNewLogFile(string FileName)
{
IAppender[] appenders = LogManager.GetLogger(TC3Logger.GetType()).Logger.Repository.GetAppenders();
foreach (TC3DataLogger rfa in appenders.OfType<TC3DataLogger>())
{
rfa.File = FileName;
rfa.MaxFileSize = MaxFileSizeKB;
//sub system that the configuration for this appender has changed.
rfa.ActivateOptions();
TC3datalogRFA = rfa;
}
}
现在,每当我创建一个新的日志文件时,我的所有其他记录器都会记录到这个文件。如何同时登录到不同的文件?我试过这个:
public void WriteToLog(int CSNum, string Message, string LogfileName)
{
if (!TC3LogsDictionary[CSNum].Logging) return;
TC3LogsDictionary[CSNum].TC3datalogRFA.File = TC3LogsDictionary[CSNum].LogFileName;
TC3LogsDictionary[CSNum].TC3datalogRFA.ActivateOptions();
TC3LogsDictionary[CSNum].TC3Logger.Info(CSNum, Message);
}
但每次尝试登录文件时,我都会收到新文件。
记录到不同文件的能力将是特定appender的一个功能。您似乎在使用某种自定义的appender,我不知道这个appender是否具有该功能。我不认为任何一个标准的log4net文件附加程序都能做到这一点。您可以通过创建一个继承自Log4net.Appender.AppenderSkeleton
的类来创建自己的appender。这里有一个教程,给出了如何执行的示例。