【Quartz】常用方法的使用方式(三)
前言
总结了一下quartz组件的一些常用方法,以备将来不时之需。哈哈,看着挺简单有些好是值得笔记一下的。好记性不如烂笔头吗?
代码部分:
方法类内容:
public class ExamplesGo
{
static ISchedulerFactory schedFact = new StdSchedulerFactory();
public static IScheduler sched = schedFact.GetScheduler(); }
任务触发器分离实现:
#region 1.运行任务【所有】
/// <summary>
/// 运行任务
/// </summary>
public void Run()
{
if (sched != null)
sched.Start();
}
#endregion #region 2.添加job
/// <summary>
/// 添加job
/// </summary>
public void AddJob()
{
IJobDetail job = JobBuilder.Create<HelloJob>()
.WithIdentity("HelloJob", "group1")
.StoreDurably()
.Build();
sched.AddJob(job, true);
}
#endregion #region 3.添加触发器
/// <summary>
/// 添加触发器
/// </summary>
/// <param name="job">需要添加触发器的job</param>
public void AddTrigger(IJobDetail job)
{
ITrigger trigger = TriggerBuilder.Create()
.WithIdentity("myTrigger", "group1")
.WithCronSchedule("0/5 * * * * ?") //5秒执行一次
.ForJob(job)
.Build();
sched.ScheduleJob(trigger);
}
public void AddTrigger1(IJobDetail job)
{
ITrigger trigger = TriggerBuilder.Create()
.WithIdentity("myTrigger2", "group1")
.WithCronSchedule("0/1 * * * * ?") //5秒执行一次
.ForJob(job)
.Build();
sched.ScheduleJob(trigger);
}
#endregion #region 4.根据key返回Job
/// <summary>
/// 根据key返回Job
/// </summary>
/// <param name="jobName">需要查找的job名称</param>
/// <returns></returns>
public IJobDetail GetJob(string jobName)
{ JobKey jobKey = sched.GetJobKeys(GroupMatcher<JobKey>.AnyGroup()).ToList().Where(b => b.Name == jobName).FirstOrDefault();
return sched.GetJobDetail(jobKey);
}
#endregion
基本的暂停,恢复,删除:
#region 5.暂停任务[全部暂停]
/// <summary>
/// 暂停任务
/// </summary>
public void PauseAll()
{
if (sched != null)
sched.PauseAll();
}
#endregion #region 6.暂停任务【单个任务】
/// <summary>
/// 暂停任务
/// </summary>
/// <param name="jobName">需要暂停任务的名称</param>
public void Shutdown(string jobName)
{
if (sched != null)
{
JobKey jobKey = sched.GetJobKeys(GroupMatcher<JobKey>.AnyGroup()).ToList().Where(b => b.Name == jobName).FirstOrDefault();
sched.PauseJob(jobKey);
} }
#endregion #region 7.恢复当前任务
/// <summary>
/// 恢复当前任务
/// </summary>
/// <param name="jobName">需要恢复任务的名称</param>
public void ResumeJob(string jobName)
{
if (sched != null)
{
JobKey jobKey = sched.GetJobKeys(GroupMatcher<JobKey>.AnyGroup()).ToList().Where(b => b.Name == jobName).FirstOrDefault();
sched.ResumeJob(jobKey);
} }
#endregion #region 8.恢复所有任务
/// <summary>
/// 恢复所有任务
/// </summary>
public void ResumeJobAll()
{
if (sched != null)
{
sched.ResumeAll();
} }
#endregion #region 9.删除当前任务
/// <summary>
/// 删除当前任务
/// </summary>
/// <param name="jobName">删除任务名称</param>
public void DeleteJob(string jobName)
{
if (sched != null)
{
JobKey jobKey = sched.GetJobKeys(GroupMatcher<JobKey>.AnyGroup()).ToList().Where(b => b.Name == jobName).FirstOrDefault();
sched.DeleteJob(jobKey);
}
}
#endregion #region 10.删除所有任务
/// <summary>
/// 删除所有任务
/// </summary>
public void DeleteJobAll()
{
if (sched != null)
{
sched.Clear();
}
}
#endregion
最后一些复杂点的查询:
#region 11.返回所有任务键
/// <summary>
/// 返回所有任务键
/// </summary>
/// <returns></returns>
public List<JobKey> GetJobAll()
{
//获取所有job
List<JobKey> jobKeys = sched.GetJobKeys(GroupMatcher<JobKey>.AnyGroup()).ToList();
return jobKeys;
}
#endregion #region 12.返回所有的触发器
/// <summary>
/// 返回所有的触发器
/// </summary>
/// <returns></returns>
public List<TriggerKey> GetTrigAll()
{
List<TriggerKey> trigKeys = sched.GetTriggerKeys(GroupMatcher<TriggerKey>.AnyGroup()).ToList();
return trigKeys;
}
#endregion #region 13.返回job对应的trigger
/// <summary>
/// 返回job对应的trigger
/// </summary>
/// <param name="jobName">任务名称</param>
/// <returns></returns>
public List<ITrigger> GetJobToTrig(string jobName)
{
JobKey jobKey = sched.GetJobKeys(GroupMatcher<JobKey>.AnyGroup()).ToList().Where(b => b.Name == jobName).FirstOrDefault();
List<ITrigger> triggerList = sched.GetTriggersOfJob(jobKey).ToList();
return triggerList;
}
#endregion
最后添加的两个一个关闭组件和修改触发器:
#region 14.关闭所有任务
/// <summary>
/// 关闭所有任务
/// </summary>
public void Shutdown()
{
if (sched != null)
sched.Shutdown();
}
#endregion #region 15.修改任务触发器
public void ModiyTrig()
{
ITrigger trigger = TriggerBuilder.Create()
.WithIdentity("myTrigger", "group1")
// .StartAt(runTime)
.WithCronSchedule("0/10 * * * * ?") //10秒执行一次
.Build();
sched.RescheduleJob(trigger.Key, trigger);
sched.Start();
}
#endregion
【Quartz】常用方法的使用方式(三)的更多相关文章
- 7. Callable 创建线程的方式三
package com.gf.demo06; import java.util.concurrent.Callable; import java.util.concurrent.ExecutionEx ...
- H5 67-清除浮动方式三
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Java线程的创建方式三:Callable(四)
一.Java实现多线程的三种方式 方式一:继承Thread类: public class Test extends Thread { public static void main(String[] ...
- 正确停止线程的方式三 使用Thread类中的内置的中断标记位-----------不熟悉
package charpter10; public class Processor implements Runnable { @Override public void run() { for ( ...
- Android MVP模式简单易懂的介绍方式 (三)
Android MVP模式简单易懂的介绍方式 (一) Android MVP模式简单易懂的介绍方式 (二) Android MVP模式简单易懂的介绍方式 (三) 讲完M和P,接下来就要讲V了.View ...
- 八 Struts2访问Servlet的API方式三:接口注入
Struts2访问Servlet的API方式三:接口注入 通过实现ServletRequestAware, ServletContextAware 接口,拿到Request.ServletContex ...
- Java之创建线程的方式三:实现Callable接口
import java.util.concurrent.Callable;import java.util.concurrent.ExecutionException;import java.util ...
- Java之解决线程安全问题的方式三:Lock锁
import java.util.concurrent.locks.ReentrantLock; /** * 解决线程安全问题的方式三:Lock锁 --- JDK5.0新增 * * 1. 面试题:sy ...
- 创建线程的方式三:实现Callable接口-----JDK5.0 新增
package com.yhqtv.java2; /* * 创建线程的方式三:实现Callable接口-----JDK5.0 新增 * * 如何理解实现Callable接口的方式创建多线程比实现Run ...
- 创建执行线程方式三:实现Callable接口
Callable接口 ① Java 5.0 在 java.util.concurrent 提供了一个新的创建执行 线程的方式:Callable 接口② Callable 接口类似于 Runnable, ...
随机推荐
- Python学习笔记 - 迭代Iteration
#!/usr/bin/env python3 # -*- coding: utf-8 -*- d = {'a': 1, 'b': 2, 'c': 3} for key in d: # 默认迭代是key ...
- 如何实现 集群化/Session 复制-doc(cluster-howto.html)
源文档链接: http://tomcat.apache.org/tomcat-6.0-doc/cluster-howto.html 翻译日期: 2014年3月19日 翻译人员: 铁锚 感受: Tomc ...
- Otto事件总线框架的使用
Otto是一个在Android中的事件总线框架,它是square的一个开源框架,具体介绍点击这里,项目下载点击这里 为什么要使用Otto事件总线: 通常来说在Android中: 1.Activity与 ...
- ubuntu 的挂起与休眠
待机 计算机将目前的运行状态等数据存放在内存,关闭硬盘.外设等设备,进入等待状态.此时内存仍然需要电力维持其数据,但整机耗电很少.恢复时计算机从内存读 出数据,回到挂起前的状态,恢复速度较快.一般笔记 ...
- Erlang cowboy 入门参考之现代Web的发展历史
Erlang cowboy 入门参考之现代Web发展史 原文: http://ninenines.eu/docs/en/cowboy/1.0/guide/modern_web/ 让我回顾一下web技术 ...
- mt6577驱动开发 笔记版
3 Preloader & Uboot 3.1 Preloader 3.1.1Preloader结构 Preloader的主题结构在文件:"alps\mediatek\platfor ...
- XMPP系列(二)----用户注册和用户登录功能
1.创建一个新工程 2.导入XMPP框架 最新的XMPP框架下载地址:https://github.com/robbiehanson/XMPPFramework 将XMPP的几个文件夹拖进工程中,需要 ...
- ZooKeeper 会话超时
1.会话概述 在ZooKeeper中,客户端和服务端建立连接后,会话随之建立,生成一个全局唯一的会话ID(Session ID).服务器和客户端之间维持的是一个长连接,在SESSION_TIMEOUT ...
- objective-c中@autoreleasepool的用法
objc中关于自动释放池,有两种语法,一种old-fashioned是: NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init]; //d ...
- C语言二维数组实现扫雷游戏
#include<stdio.h> //使用二维数组实现 扫雷 int main() { char ui[8][8]={ '+','+','+','+','+','+','+','+', ...