我目前正在使用Quartz.net和CronSchedule创建一个调度程序。我想发送关于'Jobs'的信息,比如执行时间和完成时间到.txt文件或记录信息的东西,但是我不知道如何处理这个。
任何帮助?
答案 0 :(得分:0)
您可以使用log4net,我建议为每个作业单独记录。
开始使用调度程序之前:
var location = System.Reflection.Assembly.GetExecutingAssembly().Location;
log4net.Config.XmlConfigurator.Configure(new System.IO.FileInfo(location + ".config"));
在每个扩展IJob的类中(所以,在每个Job中):
var logger = log4net.LogManager.GetLogger("TestJobLogger");
每个作业显然"TestJobLogger"
不同。
在App.config
插入此内容,您拥有的每个作业都有一个<logger>
和一个<appender>
:
<configuration>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
</configSections>
...
<log4net>
<appender name="AppenderTestJob" type="log4net.Appender.RollingFileAppender">
<appendToFile value="true" />
<rollingStyle value="Composite" />
<datePattern value=".yyyyMMdd-HH" />
<param name="ImmediateFlush" value="true" />
<maxSizeRollBackups value="10" />
<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
<file type="log4net.Util.PatternString" value="C:\PathToSaveFile\" />
<datePattern value="'test.'yyyyMMdd'.log'" />
<staticLogFileName value="false" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date{dd-MM-yyyy HH:mm:ss.fff} [%t] [%-5p] (%c) - %m%n" />
</layout>
</appender>
<root>
<level value="INFO" />
</root>
<logger name="TestJobLogger" additivity="false">
<level value="INFO" />
<appender-ref ref="AppenderTestJob" />
</logger>
</log4net>
现在,您只需使用logger.Debug("TESTTTTTT");
进行日志记录。