什么是quartz.net如何开始使用它?
答案 0 :(得分:10)
答案 1 :(得分:1)
您可以查看src \ Quartz.Examples文件夹中的示例。
答案 2 :(得分:-1)
你需要首先想到几点,如果想在内存中使用Quartz或者存储在数据库中,它会启动服务器等等。 之后,你必须创建一个类来管理你的日程表,另一个类包含你想要运行的作业,我所说的只是一个简单的例子。我将在以下场景中演示如何执行此操作: Sqlite用于存储数据,Job类包含日志,其他所有内容都包含Log。并将在每天上午10:30运行。
你的web.config
<add key="quartz.scheduler.instanceName" value="ServerScheduler" />
<add key="quartz.threadPool.type" value="Quartz.Simpl.SimpleThreadPool, Quartz" />
<add key="quartz.threadPool.threadCount" value="10" />
<add key="quartz.threadPool.threadPriority" value="2" />
<add key="quartz.jobStore.type" value="Quartz.Impl.AdoJobStore.JobStoreTX, Quartz" />
<add key="quartz.jobStore.dataSource" value="default" />
<add key="quartz.dataSource.default.connectionString" value="Data Source=yourdb.db;Version=3;Foreign Keys=ON;" />
<add key="quartz.jobStore.tablePrefix" value="QRTZ_" />
<add key="quartz.jobStore.clustered" value="false" />
<add key="quartz.jobStore.lockHandler.type" value="Quartz.Impl.AdoJobStore.UpdateLockRowSemaphore, Quartz" />
<add key="quartz.jobStore.driverDelegateType" value="Quartz.Impl.AdoJobStore.StdAdoDelegate, Quartz" />
<add key="quartz.dataSource.default.provider" value="SQLite-1094" />
<add key="quartz.jobStore.useProperties" value="true" />
<add key="quartz.scheduler.exporter.type" value="Quartz.Simpl.RemotingSchedulerExporter, Quartz" />
<add key="quartz.scheduler.exporter.port" value="555" />
<add key="quartz.scheduler.exporter.bindName" value="QuartzScheduler" />
<add key="quartz.scheduler.exporter.channelType" value="tcp" />
创建一个名为Schedule.cs的类:
public static class Schedule
{
private static readonly ILog logger = LogManager.GetLogger(typeof(Schedule));
public static ITrigger BuildTrigger(int hour, int minute)
{
var trigger = TriggerBuilder.Create()
.StartNow()
.WithSchedule(CronScheduleBuilder.DailyAtHourAndMinute(hour,minute))
.Build();
return trigger;
}
public static IScheduler InicializarScheduler()
{
var scheduleMigracao = Schedule.GetScheduler();
if (!scheduleMigracao.IsStarted)
scheduleMigracao.Start();
logger.Info("Scheduler started successfully");
return scheduleMigracao;
}
public static IJobDetail BuildJogDetail<T>(string WorkFlowId, string Group) where T : IJob
{
return JobBuilder.Create<T>()
.WithIdentity(WorkFlowId, Group)
.RequestRecovery()
.Build();
}
private static IScheduler GetScheduler()
{
try
{
IScheduler scheduler = SchedulerRepository.Instance.Lookup("DefaultQuartzScheduler");
if (scheduler == null)
{
var factoryScheduler = new StdSchedulerFactory();
return factoryScheduler.GetScheduler();
}
else
{
return scheduler;
}
}
catch (Exception ex)
{
logger.Error("Server initialization failed:" + ex.Message, ex);
throw;
}
}
}
创建一个名为TestJob.cs的类
public class TestJob : IInterruptableJob
{
private static readonly ILog Log = LogManager.GetLogger(typeof(TestJob));
public void Interrupt()
{
}
public void Execute(IJobExecutionContext context)
{
try
{
Log.DebugFormat("{0}****{0}Job {1} Start @ {2} next scheduled for {3}{0}***{0}",
Environment.NewLine,
context.JobDetail.Key,
context.FireTimeUtc.Value.ToString("r"),
context.NextFireTimeUtc.Value.ToString("r"));
//implement your logic
Log.DebugFormat("{0}****{0}Job {1} executed with sucess at @ {2}",
Environment.NewLine,
context.JobDetail.Key,
context.FireTimeUtc.Value.ToString("r"));
}
catch (Exception ex)
{
Log.DebugFormat("{0}***{0}Failed: {1}{0}***{0}", Environment.NewLine, ex.Message);
}
}
}
在你的Global.asax地方:
public class Global : System.Web.HttpApplication
{
private static void BuildingQuartzMetadataSqLite1090()
{
var metaData = new DbMetadata();
metaData.AssemblyName = "System.Data.SQLite, Version = 1.0.94.0,Culture=neutral, PublicKeyToken=db937bc2d44ff139";
metaData.BindByName = true;
metaData.CommandBuilderType = typeof(System.Data.SQLite.SQLiteCommandBuilder);
metaData.CommandType = typeof(System.Data.SQLite.SQLiteCommand);
metaData.ConnectionType = typeof(System.Data.SQLite.SQLiteConnection);
metaData.ExceptionType = typeof(System.Data.SQLite.SQLiteException);
metaData.ParameterDbType = typeof(System.Data.SQLite.TypeAffinity);
metaData.ParameterDbTypePropertyName = "DbType";
metaData.ParameterNamePrefix = "@";
metaData.ParameterType = typeof(System.Data.SQLite.SQLiteParameter);
metaData.UseParameterNamePrefixInParameterCollection = true;
DbProvider.RegisterDbMetadata("SQLite-1094",metaData);
}
protected void Application_Start(object sender, EventArgs e)
{
BuildingQuartzMetadataSqLite1090();
Schedule.InicializarScheduler();
Schedule.ScheduleJob(Schedule.BuildJogDetail<TestJob>("TestJob","GrupoTest"), Schedule.BuildTrigger(10, 30));
}
}
任何问题只是问