一、概述
1、quartz.net 是一款从java quartz 上延伸出来的定时任务框架。
2、我在网上看到很多大神写过关于quartz.net 的博客、文章等,在这些博客文章里也学会了很多关于quartz的知识。今天博主也想写一篇关于quartz的文章(不足之处望大神斧正),希望能帮助正在学习quartz路上的兄弟姐妹,顺便也巩固自己。
3、quartz这篇博客会从最基础的开始,之后会逐渐的升级,如果有喜欢的兄弟姐妹,请关注我的博客,博主会持续更新
二、搭建
1、打开vs创建新的mvc空项目,取名:QuartzMVC 如图
2、完成上一步,接下来我们安装quart
(1)打开vs 工具-->库程序包管理器-->程序包管理台 打开程序包管理台之后 输入
(2)安装成功之后,你会看见项目里多了一个 job_scheduling_data_2_0.xsd文件(无需理会)
3、同第2步,我们相继安装 log4net.dll 、 Common.Logging.dll 、Common.Logging.Core.dll 3个日志工具
(1)安装好如下图
4、配置web.config,添加日志输出路径 如图
三、代码
1、添加一个控制器取名Home
(1)在Home控制器里添加一个视图Index
(2)在QuartzMVC项目下建立日志工具类 取名:LogTool 并编写如下代码
public static void DetailLogRecord(string type, LogTool.FolderCreationType folderCrationType, string content, bool isErasable, string filename = null)
{
string folderPrefixPath = (System.Configuration.ConfigurationManager.AppSettings["localLogPath"] ?? "c:\\test_log_tem") + "\\" + type;
string folderPath = "";
try
{
switch (folderCrationType)
{
default: folderPath = folderPrefixPath; break;
}
if (!Directory.Exists(folderPath))
{
Directory.CreateDirectory(folderPath);
}
string filePath = folderPath + "\\" + (filename ?? DateTime.Now.ToString("yyyyMMdd")) + ".log";
content = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff") + " :\r\n" + content + "\r\n";
if (isErasable) LogTool.RecordNewFileLog(filePath, content);
else LogTool.RecordConsecutiveLog(filePath, content);
}
catch
{
throw;
} } public enum FolderCreationType
{
None
} private static void RecordConsecutiveLog(string filePhysicalUrl, string pursuitContent)
{
System.IO.FileStream fs = new System.IO.FileStream(filePhysicalUrl, FileMode.OpenOrCreate, FileAccess.Write);
System.IO.StreamWriter m_streamWriter = new System.IO.StreamWriter(fs);
m_streamWriter.BaseStream.Seek(, SeekOrigin.End); string resultStr = Environment.NewLine + pursuitContent; m_streamWriter.WriteLine(resultStr);
m_streamWriter.Flush();
m_streamWriter.Close();
fs.Close();
} private static void RecordNewFileLog(string filePhysicalUrl, string content)
{
System.IO.StreamWriter sw = new System.IO.StreamWriter(filePhysicalUrl);
sw.WriteLine(content);
sw.Close();
} private static void CreateFolder(string url)
{
if (Directory.Exists((url)) == false)
{
Directory.CreateDirectory((url));
}
}
(3)打开视图Index添加如下代码
@using (Html.BeginForm("FirstQuartz", "Home", FormMethod.Post))
{
<input type="submit" value="点击开启第一个定时任务"/>
}
(4)在QuartzMVC项目下的Model 文件夹下建立JobClass类并继承IJob接口 代码如下
public class JobClass:IJob
{
//日志
private static ILog _log = LogManager.GetLogger(typeof(JobClass)); /// <summary>
/// 构造方法
/// </summary>
public JobClass()
{ }
/// <summary>
/// 作业默认接口
/// </summary>
/// <param name="context"></param>
public void Execute(IJobExecutionContext context)
{
LogTool.DetailLogRecord("a", LogTool.FolderCreationType.None, "我的第一个任务", false);
}
}
(5)打开Home控制器添加方法“FirstQuartz”如下代码
public void FirstQuartz()
{
StdSchedulerFactory schedulerFactory = new StdSchedulerFactory();
//得到调度
IScheduler sched = schedulerFactory.GetScheduler();
//构造一个调度工厂
LogTool.DetailLogRecord("a", LogTool.FolderCreationType.None, "创建调度器成功", false);
sched.Start(); IJobDetail job = JobBuilder.Create<JobClass>()
.WithIdentity("作业名称", "作业分组")
.Build();
// 触发作业
ITrigger trigger = TriggerBuilder.Create() #region 使用 时间间隔 先不介绍
//.WithIdentity("myTrigger", "group1")
//.StartNow()
//.WithSimpleSchedule(x => x
// .WithIntervalInSeconds(5)
// .RepeatForever())
//.Build();
#endregion #region 使用cron 规则 .WithIdentity("触发器名称", "触发器分组")
.WithCronSchedule("/5 * * ? * *") // 每隔五秒执行一次 这个表达式我们将在下一篇介绍
.StartAt(DateTime.UtcNow)
.WithPriority()
.Build();
#endregion
// 将作业和触发器添加到调度器
sched.ScheduleJob(job, trigger); // 2天后关闭作业调度 定时关闭任务实例
//Thread.Sleep(TimeSpan.FromDays(2)); // _sched.Shutdown(); // 结束
}
(5)到这里我们的第一个简单的quartz任务就搭建完成。
2、这里只写了开启任务的方法,没有写关闭的方法,如果需要可以*添加
(1)关闭方法为 _sched.Shutdown(),在开启方法里最后注释了,读者可以单独分离出来
四、测试
1、运行项目会看到 如下图页面
(1)点击按钮开启任务
(2)打开本地磁盘e 你会看到一个文件夹QuartzLog里面有一个日志文件就是你的任务记录 如图
(3)我们可以看到任务是我们定义好的每五秒钟执行一次
五、源码及说明
1、注:有事请留言,要源码请加qq群:460362190
2、如果喜欢我的文章请点关注O(∩_∩)O~~ ,有问题留言哦