Quartz.Net工作到日志文件

时间:2018-04-05 16:39:07

标签: c# scheduled-tasks quartz-scheduler quartz.net

我目前正在使用Quartz.net和CronSchedule创建一个调度程序。我想发送关于'Jobs'的信息,比如执行时间和完成时间到.txt文件或记录信息的东西,但是我不知道如何处理这个。

任何帮助?

1 个答案:

答案 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");进行日志记录。