天天看點

Quartz.net官方開發指南 第一課:使用Quartz.net

使用scheduler之前應首先執行個體化它。使用SchedulerFactory可以完成scheduler的執行個體化。使用者可直接地執行個體化這個工廠類并且直接使用工廠的執行個體(例如下面的例子)。

一旦一個scheduler被執行個體化,它就可以被啟動(start),并且處于駐留模式,直到被關閉(shutdown)。注意,一旦scheduler被關閉(shutdown),則它不能再重新啟動,除非重新執行個體化它。除非scheduler 被啟動或者不處于暫停狀态,否則觸發器不會被觸發(任務也不能被執行)。

下面是一個代碼片斷,這個代碼片斷執行個體化并且啟動了一個scheduler,接着将一個要執行的任務納入了程序。

Quartz.net官方開發指南 第一課:使用Quartz.net

using  Common.Logging;

Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net

namespace  Quartz.Examples.Example1

Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net

{

Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net

    /// <summary>

Quartz.net官方開發指南 第一課:使用Quartz.net

    /// This is just a simple job that says "Hello" to the world.

Quartz.net官方開發指南 第一課:使用Quartz.net

    /// </summary>

Quartz.net官方開發指南 第一課:使用Quartz.net

    /// <author>Bill Kratzer</author>

Quartz.net官方開發指南 第一課:使用Quartz.net

    public class HelloJob : IJob

Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net

{

Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net

        private static ILog _log = LogManager.GetLogger(typeof(HelloJob));

Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net

        /// <summary> 

Quartz.net官方開發指南 第一課:使用Quartz.net

        /// Empty constructor for job initilization

Quartz.net官方開發指南 第一課:使用Quartz.net

        /// <p>

Quartz.net官方開發指南 第一課:使用Quartz.net

        /// Quartz requires a public empty constructor so that the

Quartz.net官方開發指南 第一課:使用Quartz.net

        /// scheduler can instantiate the class whenever it needs.

Quartz.net官方開發指南 第一課:使用Quartz.net

        /// </p>

Quartz.net官方開發指南 第一課:使用Quartz.net

        /// </summary>

Quartz.net官方開發指南 第一課:使用Quartz.net

        public HelloJob()

Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net

{

Quartz.net官方開發指南 第一課:使用Quartz.net

        }

Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net

        /// <summary> 

Quartz.net官方開發指南 第一課:使用Quartz.net

        /// Called by the <see cref="IScheduler" /> when a

Quartz.net官方開發指南 第一課:使用Quartz.net

        /// <see cref="Trigger" /> fires that is associated with

Quartz.net官方開發指南 第一課:使用Quartz.net

        /// the <see cref="IJob" />.

Quartz.net官方開發指南 第一課:使用Quartz.net

        /// </summary>

Quartz.net官方開發指南 第一課:使用Quartz.net

        public virtual void  Execute(JobExecutionContext context)

Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net

{

Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net

            // Say Hello to the World and display the date/time

Quartz.net官方開發指南 第一課:使用Quartz.net

            _log.Info(string.Format("Hello World! - {0}", System.DateTime.Now.ToString("r")));

Quartz.net官方開發指南 第一課:使用Quartz.net

        }

Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net

    }

Quartz.net官方開發指南 第一課:使用Quartz.net

}

Quartz.net官方開發指南 第一課:使用Quartz.net

            ILog log  =  LogManager.GetLogger( typeof (SimpleExample));

Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net

            log.Info( " ------- Initializing ---------------------- " );

Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net

             //  First we must get a reference to a scheduler

Quartz.net官方開發指南 第一課:使用Quartz.net

            ISchedulerFactory sf  =   new  StdSchedulerFactory();

Quartz.net官方開發指南 第一課:使用Quartz.net

            IScheduler sched  =  sf.GetScheduler();

Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net

            log.Info( " ------- Initialization Complete ----------- " );

Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net

            log.Info( " ------- Scheduling Jobs ------------------- " );

Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net

             //  computer a time that is on the next round minute

Quartz.net官方開發指南 第一課:使用Quartz.net

            DateTime runTime  =  TriggerUtils.GetEvenMinuteDate( new  NullableDateTime(DateTime.Now));

Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net

             //  define the job and tie it to our HelloJob class

Quartz.net官方開發指南 第一課:使用Quartz.net

            JobDetail job  =   new  JobDetail( " job1 " ,  " group1 " ,  typeof (HelloJob));

Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net

             //  Trigger the job to run on the next round minute

Quartz.net官方開發指南 第一課:使用Quartz.net

            SimpleTrigger trigger  =   new  SimpleTrigger( " trigger1 " ,  " group1 " , runTime);

Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net

             //  Tell quartz to schedule the job using our trigger

Quartz.net官方開發指南 第一課:使用Quartz.net

            sched.ScheduleJob(job, trigger);

Quartz.net官方開發指南 第一課:使用Quartz.net

            log.Info( string .Format( " {0} will run at: {1} " , job.FullName, runTime.ToString( " r " )));

Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net

             //  Start up the scheduler (nothing can actually run until the 

Quartz.net官方開發指南 第一課:使用Quartz.net

             //  scheduler has been started)

Quartz.net官方開發指南 第一課:使用Quartz.net

            sched.Start();

Quartz.net官方開發指南 第一課:使用Quartz.net

            log.Info( " ------- Started Scheduler ----------------- " );

Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net

             //  wait long enough so that the scheduler as an opportunity to 

Quartz.net官方開發指南 第一課:使用Quartz.net

             //  run the job!

Quartz.net官方開發指南 第一課:使用Quartz.net

            log.Info( " ------- Waiting 90 seconds

Quartz.net官方開發指南 第一課:使用Quartz.net

 ------------- " );

Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net

             //  wait 90 seconds to show jobs

Quartz.net官方開發指南 第一課:使用Quartz.net

            Thread.Sleep( 90   *   1000 );

Quartz.net官方開發指南 第一課:使用Quartz.net
Quartz.net官方開發指南 第一課:使用Quartz.net

             //  shut down the scheduler

Quartz.net官方開發指南 第一課:使用Quartz.net

            log.Info( " ------- Shutting Down --------------------- " );

Quartz.net官方開發指南 第一課:使用Quartz.net

            sched.Shutdown( true );

Quartz.net官方開發指南 第一課:使用Quartz.net

            log.Info( " ------- Shutdown Complete ----------------- " );

如您所見,使用 quartz 相當簡單,在第二課中,我們将給出一個 Job 和 Trigger 的快速預覽,這樣就能夠充分了解這個例子。