触发器执行的次数

时间:2018-05-22 14:32:07

标签: c# quartz-scheduler quartz.net

我正在尝试将触发器触发的次数保存到数据库表中,但我在quartz-scheduler.net中找不到任何关于此的内容。我可以调用任何方法来实现这个目标吗?

使用简单的触发器,有一个.GetTimesTriggered()方法。 cron触发器是否有任何等效物?

1 个答案:

答案 0 :(得分:0)

您可以简单地实现ISchedulerListener。 我已经实现了它,如下面的一些登录触发器执行

    public class QuartzSchedulerListener : ISchedulerListener//todo R & D to catch schdeuler error/invalid shutdown event and do possible implementation there
{
    private static readonly log4net.ILog Logger = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);

    public Task JobScheduled(ITrigger trigger, CancellationToken cancellationToken = default(CancellationToken))
    {
        var t = Task.Factory.StartNew
        (() =>
        {
            Logger.Debug("Quartz Scheduler JobScheduled");

        });
        return t;
    }

    public Task JobUnscheduled(TriggerKey triggerKey, CancellationToken cancellationToken = default(CancellationToken))
    {
        var t = Task.Factory.StartNew
        (() =>
        {
            Logger.Debug("Quartz Scheduler JobUnscheduled");

        });
        return t;
    }

    public Task TriggerFinalized(ITrigger trigger, CancellationToken cancellationToken = default(CancellationToken))
    {
        var t = Task.Factory.StartNew
        (() =>
        {
            Logger.Debug("Quartz Scheduler TriggerFinalized");

        });
        return t;
    }

    public Task TriggerPaused(TriggerKey triggerKey, CancellationToken cancellationToken = default(CancellationToken))
    {
        var t = Task.Factory.StartNew
        (() =>
        {
            Logger.Debug("Quartz Scheduler TriggerPaused");

        });
        return t;
    }

    public Task TriggersPaused(string triggerGroup, CancellationToken cancellationToken = default(CancellationToken))
    {
        var t = Task.Factory.StartNew
        (() =>
        {
            Logger.DebugFormat("Quartz Scheduler TriggersPaused {0}", triggerGroup);

        });
        return t;
    }

    public Task TriggerResumed(TriggerKey triggerKey, CancellationToken cancellationToken = default(CancellationToken))
    {
        var t = Task.Factory.StartNew
        (() =>
        {
            Logger.Debug("Quartz Scheduler TriggersPaused");

        });
        return t;
    }

    public Task TriggersResumed(string triggerGroup, CancellationToken cancellationToken = default(CancellationToken))
    {
        var t = Task.Factory.StartNew
        (() =>
        {
            Logger.DebugFormat("Quartz Scheduler TriggersResumed {0}", triggerGroup);

        });
        return t;
    }

    public Task JobAdded(IJobDetail jobDetail, CancellationToken cancellationToken = default(CancellationToken))
    {
        var t = Task.Factory.StartNew
        (() =>
        {
            Logger.Debug("Quartz Scheduler JobAdded");

        });
        return t;
    }

    public Task JobDeleted(JobKey jobKey, CancellationToken cancellationToken = default(CancellationToken))
    {
        var t = Task.Factory.StartNew
        (() =>
        {
            Logger.Debug("Quartz Scheduler JobDeleted");

        });
        return t;
    }

    public Task JobPaused(JobKey jobKey, CancellationToken cancellationToken = default(CancellationToken))
    {
        var t = Task.Factory.StartNew
        (() =>
        {
            Logger.Debug("Quartz Scheduler JobPaused");

        });
        return t;
    }

    public Task JobInterrupted(JobKey jobKey, CancellationToken cancellationToken = default(CancellationToken))
    {
        var t = Task.Factory.StartNew
        (() =>
        {
            Logger.Debug("Quartz Scheduler JobInterrupted");

        });
        return t;
    }

    public Task JobsPaused(string jobGroup, CancellationToken cancellationToken = default(CancellationToken))
    {
        var t = Task.Factory.StartNew
        (() =>
        {
            Logger.DebugFormat("Quartz Scheduler JobsPaused {0}", jobGroup);

        });
        return t;
    }

    public Task JobResumed(JobKey jobKey, CancellationToken cancellationToken = default(CancellationToken))
    {
        var t = Task.Factory.StartNew
        (() =>
        {
            Logger.Debug("Quartz Scheduler JobResumed");

        });
        return t;
    }

    public Task JobsResumed(string jobGroup, CancellationToken cancellationToken = default(CancellationToken))
    {
        var t = Task.Factory.StartNew
        (() =>
        {
            Logger.DebugFormat("Quartz Scheduler JobsResumed {0}",jobGroup);

        });
        return t;
    }

    public Task SchedulerError(string msg, SchedulerException cause, CancellationToken cancellationToken = default(CancellationToken))
    {
        var t = Task.Factory.StartNew
        (() =>
        {
            Logger.DebugFormat("Quartz Scheduler is Error State message:{0}", msg);
            if (cause != null)
            {
                Logger.Error(cause);
            }
        });
        return t;
    }

    public Task SchedulerInStandbyMode(CancellationToken cancellationToken = default(CancellationToken))
    {
        var t = Task.Factory.StartNew
        (() =>
        {
            Logger.Debug("Quartz Scheduler is in Stand By Mode");

        });
        return t;
    }

    public Task SchedulerStarted(CancellationToken cancellationToken = default(CancellationToken))
    {
        var t = Task.Factory.StartNew
        (() =>
        {
            Logger.Debug("Quartz Scheduler is Started");

        });
        return t;
    }

    public Task SchedulerStarting(CancellationToken cancellationToken = default(CancellationToken))
    {
        var t = Task.Factory.StartNew
        (() =>
        {
            Logger.Debug("Quartz Scheduler is Starting");

        });
        return t;
    }

    public Task SchedulerShutdown(CancellationToken cancellationToken = default(CancellationToken))
    {
        var t = Task.Factory.StartNew
        (() =>
        {
            Logger.Debug("Quartz Scheduler is Shut Down");

        });
        return t;
    }

    public Task SchedulerShuttingdown(CancellationToken cancellationToken = default(CancellationToken))
    {
        var t = Task.Factory.StartNew
        (() =>
        {
            Logger.Debug("Quartz Scheduler is Shutting Down");

        });
        return t;
    }

    public Task SchedulingDataCleared(CancellationToken cancellationToken = default(CancellationToken))
    {
        var t = Task.Factory.StartNew
        (() =>
        {
            Logger.Debug("Quartz Scheduler SchedulingDataCleared");

        });
        return t;
    }
}



  StdSchedulerFactory factory = new StdSchedulerFactory();
                var MyQuartzScheduler = await factory.GetScheduler();
                QuartzSchedulerListener olistener = new QuartzSchedulerListener();
                MyQuartzScheduler.ListenerManager.AddSchedulerListener(olistener);
                await MyQuartzScheduler.Start();
相关问题