(一)建立服務 QuarzServicetcp
using System.ServiceProcess;
using System.Text;ide
using Quartz;
using Quartz.Impl;this
using WinNet.Log;
namespace QuarzService
{
public partial class QuartzService : ServiceBase
{
private IScheduler scheduler;spa
public QuartzService()
{
InitializeComponent();
ISchedulerFactory schedulerFactory = new StdSchedulerFactory();
scheduler = schedulerFactory.GetScheduler();日誌
}orm
protected override void OnStart(string[] args)
{
scheduler.Start();
WriteLog.logTxt("Quartz服務成功啓動", "scheduler");
}server
protected override void OnStop()
{
scheduler.Shutdown();
WriteLog.logTxt("Quartz服務成功終止", "scheduler");
}xml
protected override void OnPause()
{
scheduler.PauseAll();
}blog
protected override void OnContinue()
{
scheduler.ResumeAll();
}
}
}rem
(二)quartz.config 配置
# You can configure your scheduler in either <quartz> configuration section
# or in quartz properties file
# Configuration section has precedence
quartz.scheduler.instanceName = ServerScheduler
# configure thread pool info
quartz.threadPool.type = Quartz.Simpl.SimpleThreadPool, Quartz
quartz.threadPool.threadCount = 10
quartz.threadPool.threadPriority = Normal
# job initialization plugin handles our xml reading, without it defaults are used
quartz.plugin.xml.type = Quartz.Plugin.Xml.XMLSchedulingDataProcessorPlugin, Quartz
quartz.plugin.xml.fileNames = ~/quartz_jobs.xml
# export this server to remoting context
quartz.scheduler.exporter.type = Quartz.Simpl.RemotingSchedulerExporter, Quartz
quartz.scheduler.exporter.port = 555
quartz.scheduler.exporter.bindName = QuartzScheduler
quartz.scheduler.exporter.channelType = tcp
quartz.scheduler.exporter.channelName = httpQuartz
寫日誌方法:
using System.Text;
using System.Windows.Forms;
using System.IO;
namespace WinNet.Log
{
public class WriteLog
{
public WriteLog()
{
}
public static void logTxt(string Msg, string name)
{
string logPath = Path.GetDirectoryName(Application.ExecutablePath);
System.IO.StreamWriter sw = System.IO.File.AppendText(logPath + "/" + name + "_" + DateTime.Now.ToString("yyyy-MM-dd") + ".txt");
sw.WriteLine(DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss ") + Msg);
sw.Close();
sw.Dispose();
}
}
}
(三)建立一個任務:WinNet.JobTask
using Quartz;
using WinNet.Log;
namespace WinNet.JobTask
{
public class JobGeneral:IJob
{
//private static readonly Common.Logging.ILog logger = Common.Logging.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
#region IJob Members
public void Execute(IJobExecutionContext context)
{
try
{
WriteLog.logTxt("DemoJob1 任務開始運行", "scheduler");
for (int i = 0; i < 10; i++)
{
WriteLog.logTxt("DemoJob1 正在運行 " + i, "scheduler");
}
WriteLog.logTxt("DemoJob1任務運行結束", "scheduler");
}
catch (Exception ex)
{
WriteLog.logTxt("Error:"+ex.ToString (), "scheduler");
}
}
#endregion
}
}
(四)安裝與卸載服務
安裝服務,寫成bat 文件
%SystemRoot%\Microsoft.NET\Framework\v4.0.30319\installutil.exe QuarzService.exe
Net Start QuarzService
sc config QuarzService start= auto
卸載服務,寫成bat 文件
%SystemRoot%\Microsoft.NET\Framework\v4.0.30319\installutil.exe /u QuarzService.exe
源碼:http://files.cnblogs.com/files/aran/ServiceSchedulerDesign.rar