在特定日期和时间仅开火一次

时间:2012-03-08 07:49:05

标签: c# asp.net quartz.net

我有Job的代码 - 只是将日志信息发送到数据库

 public class Job : IJob 
    { 
        private static readonly log4net.ILog log = 
log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod( ).DeclaringType); 
        #region IJob Members 
        public void Execute(IJobExecutionContext context) 
        { 
            // This job simply prints out its job name and the 
            // date and time that it is running 
            JobKey jobKey = context.JobDetail.Key; 
            log.InfoFormat("SimpleJob says: {0} executing at {1}", 
jobKey, DateTime.Now.ToString("r")); 
        } 
        #endregion 
    } 

我的单身调度程序类

public class Scheduler 
    { 
        static Scheduler() 
        { 
            NameValueCollection properties = new 
NameValueCollection(); 
            properties["quartz.scheduler.instanceName"] = "myApp"; 
            properties["quartz.scheduler.instanceId"] = "MyApp"; 
            properties["quartz.threadPool.type"] = 
"Quartz.Simpl.SimpleThreadPool, Quartz"; 
            properties["quartz.threadPool.threadCount"] = "10"; 
            properties["quartz.threadPool.threadPriority"] = "Normal"; 
            properties["quartz.scheduler.instanceName"] = 
"TestScheduler"; 
            properties["quartz.scheduler.instanceId"] = 
"instance_one"; 
            properties["quartz.jobStore.type"] = 
"Quartz.Impl.AdoJobStore.JobStoreTX, Quartz"; 
            properties["quartz.jobStore.useProperties"] = "true"; 
            properties["quartz.jobStore.dataSource"] = "default"; 
            properties["quartz.jobStore.tablePrefix"] = "QRTZ_"; 
            // if running MS SQL Server we need this 
            properties["quartz.jobStore.lockHandler.type"] = 
"Quartz.Impl.AdoJobStore.UpdateLockRowSemaphore, Quartz"; 
            properties["quartz.dataSource.default.connectionString"] = 
"Server=localhost;Database=quartzr;Uid=user;Pwd=pass"; 
            properties["quartz.dataSource.default.provider"] = 
"SqlServer-20"; 
            _schedulerFactory = new StdSchedulerFactory(properties); 
            _scheduler = _schedulerFactory.GetScheduler(); 
        } 
        public static IScheduler GetScheduler() 
        { 
            return _scheduler; 
        } 
        private static readonly ISchedulerFactory _schedulerFactory; 
        private static readonly IScheduler _scheduler; 
    } 

Global.asax启动调度程序

void Application_Start(object sender, EventArgs e) 
        { 
            Scheduler.GetScheduler().Start(); 
        } 

添加作业的代码

 DateTime SelectedDate = this.Calendar1.SelectedDate; 
                int hour = this.TimeSelector1.Hour; 
                int minute = this.TimeSelector1.Minute; 
                int second = this.TimeSelector1.Second; 
                // First we must get a reference to a scheduler 
                // jobs can be scheduled before sched.start() has been 
called 
                // get a "nice round" time a few seconds in the 
future... 
                DateTimeOffset startTime = DateBuilder.DateOf(hour, 
minute, second, SelectedDate.Day, SelectedDate.Month, 
SelectedDate.Year); 
                try 
                { 
                    // job1 will only fire once at date/time "ts" 
                    IJobDetail job = JobBuilder.Create<Job>() 
                        .WithIdentity("job1", "group1") 
                        .Build(); 
                    ISimpleTrigger trigger = 
(ISimpleTrigger)TriggerBuilder.Create() 
                                                                  .WithIdentity("trigger1", 
"group1") 
                                                                  .StartAt(startTime) 
                                                                  .Build(); 
                    // schedule it to run! 
                    DateTimeOffset? ft = 
Scheduler.GetScheduler().ScheduleJob(job, trigger); 
                    log.Info(job.Key + 
                             " will run at: " + ft); 
                    this.Label1.Text = "Zdarzenie dodane"; 
                } 
                catch (Exception ex) 
                { 
                    log.Error(ex.Message, ex); 
                } 

问题是作业被添加到db,但它会立即触发,而不是 具体时间由我:/我使用最新的库 Quartz.NET 2.0 beta 2 我的代码有问题吗?我使用这个API,请帮忙

3 个答案:

答案 0 :(得分:2)

Quartz.Net希望您以UTC格式传递日期和时间。尝试更改此行:

.StartAt(startTime) 

.StartAt(startTime.ToUniversalTime())

或者,确保startTime在传入之前是UTC格式。

答案 1 :(得分:0)

StartAt除了DateTimeOffest
Quartz为此

提供了DateBuilder辅助类
var minutesToFireDouble = (futureUTCtime - DateTime.UtcNow).TotalMinutes;
               var minutesToFire = (int)Math.Floor(minutesToFireDouble); // negative or zero value will set fire immediately
               var timeToFire = DateBuilder.FutureDate(minutesToFire, IntervalUnit.Minute);
               var trigger = TriggerBuilder.Create()
                                           .WithIdentity("triggerC", "groupC")
                                           .StartAt(timeToFire)
                                           .WithSimpleSchedule(x => x.WithMisfireHandlingInstructionFireNow())
                                           .Build();

答案 2 :(得分:0)

如果您已经知道需要运行任务的UTC时间,可以执行以下操作:

UTC开始时间目标:2017年9月1日中午12点

按如下方式设置Quartz“StartTime”:

var MyTaskAbcStartTime = "2017-09-01 12:00:00Z"
.StartAt(MyTaskAbcStartTime) 

参考用于utc时间格式的microsoft文档: https://docs.microsoft.com/en-us/dotnet/standard/base-types/standard-date-and-time-format-strings

希望这有助于为将来的Quartz用户节省一些时间。