- 浏览: 180789 次
- 性别:
- 来自: 南京
文章分类
- 全部博客 (103)
- JS (17)
- 算法 (2)
- SVN (2)
- DB2 (1)
- JAVA (28)
- XML (2)
- DOM (2)
- flex (1)
- axis (1)
- weblogic (2)
- oracle (3)
- Struts2 (1)
- CSS (1)
- linux (4)
- ibatis (2)
- linux crontab (1)
- JSTL (1)
- jQuery (4)
- ajaxfileupload (1)
- POI (1)
- excel (1)
- JSONArray (0)
- JSONObject (0)
- JSON (2)
- postgresql (2)
- Ruby (2)
- mysql (7)
- tomcat (1)
- quartz (2)
- mail (1)
- UEditor (1)
- maven (1)
- eclipse (1)
- HttpClient (1)
- HttpGet (1)
- HttpPost (1)
- HttpHost (1)
- CredentialsProvider (1)
最新评论
-
快到碗里来_Jerry:
16777216L*Long.parseLong(ips[0] ...
IP地址与数字相互转换 -
谷超:
不知道楼主是否有更深入的研究
Quartz数据源配置 -
谷超:
楼主,quartz配置数据库信息后,是能够把job信息保存到数 ...
Quartz数据源配置
quartz学习总结:
一、关于job:
用Quartz的行话讲,作业是一个执行任务的简单Java类。任务可以是任何Java代码。只需你实现org.quartz.Job接口并且在出现严重 错误情况下抛出JobExecutionException异常即可。Job接口包含唯一的一个方法execute(),作业从这里开始执行。一旦实现了 Job接口和execute()方法,当Quartz确定该是作业运行的时候,它将调用你的作业。Execute()方法内就完全是你要做的事情。要注 意,自己实现job时必须有一个public 的无参数的构造方法.对于job,大多数情况下都要依赖于某些具体的条件,这时,就要用到JobDataMap了。JobDataMap是Map的一个子 类,获取时很简单,直接用get方法就ok了,基于参数,我们就可以定制不同的job任务了。下面是一个简单的job,用来列举出所有的参数并且获得参数 名为name的值.
public class HelloJob implements Job {
private static Log _log = LogFactory.getLog(HelloJob.class);
public HelloJob() {
}
public void execute(JobExecutionContext context)
throws JobExecutionException {
JobDataMap jobDataMap = context.getJobDetail().getJobDataMap();
_log.info("要执行的参数如下:");
Iterator i = jobDataMap.entrySet().iterator();
while(i.hasNext()) {
Map.Entry me = (Map.Entry)i.next();
_log.info(me.getKey() + ": "+me.getValue());
}
_log.info("U Are Welcome:"+jobDataMap.get("name"));
}
}
二、关于jobdetail:
Quartz并不存储一个真正的Job实例,相反的,它通过jobdetail来定义job,并指定job的name和group,在一个调度器 (Scheduler)中,name和group是唯一被定义的,一个触发器(trigger)只能指定一个job,但多个触发器可以指定同一个job.
Scheduler的作用就是调用任务,在指定的时间执行指定的任务。主要方法如下:
scheduleJob方法:
scheduleJob(JobDetail jobDetail, Trigger trigger):把jobDetail添加到调度器中,并指定触发器trigger.在这里要注意,在同一个调度器中,jobDetail的name和 group是唯一的;Trigger的name和group也必须是唯一的。如果在trigger中指定job的name,则该name必须和 jobDetail的name保持一致,否则会抛出异常。
scheduleJob(Trigger trigger):指定的trigger中必须包含jobdetai的name.以便于让quartz知道要执行的任务,如果指定的jobdetail的 name不在调度器中的任务列表中,则会抛出JobPersistenceException异常。
deleteJob(String jobName,String groupName)方法:
删除指定的job,并且删除所有相关联的触发器。(Delete the identified Job from the Scheduler - and any associated Triggers.)
四、关于作业存储
Quartz提供两种基本作业存储类型。
第一种类型叫做RAMJobStore,它利用通常的内存来持久化调度程序信息。这种作业存储类型最容易配置、构造和运行。对许多应用来说,这种作业存储 已经足够了。然而,因为调度程序信息是存储在被分配给JVM的内存里面,所以,当应用程序停止运行时,所有调度信息将被丢失。
第二种类型称为JDBC作业存储。Quartz提供两种不同的实现,但两种实现一般都需要JDBC驱动程序和后台数据库来持久化调度程序信息。这两种类型 的不同在于你是否想要控制数据库事务或这释放控制给应用服务器例如BEA's WebLogic或Jboss。(这类似于J2EE领域中,Bean管理的事务和和容器管理事务之间的区别)这两种JDBC作业存储是:
· JobStoreTX:当你想要控制事务或工作在非应用服务器环境中是使用 (注:自己控制事务)。
· JobStoreCMT:当你工作在应用服务器环境中和想要容器控制事务时使用 (web服务器控制事务)。
五、关于触发器
Quartz中的触发器用来告诉调度程序作业什么时候触发。框架提供了一把触发器类型,但两个最常用的是SimpleTrigger和CronTrigger。SimpleTrigger为需要简单打火调度而设计。
典型地,如果你需要在给定的时间和重复次数或者两次打火之间等待的秒数打火一个作业,那么SimpleTrigger适合你。
另一方面,如果你有许多复杂的作业调度,那么或许需要CronTrigger。
CronTrigger很强大,使用复杂的时间判断来使用,效果很好。
六、关于Quartz中的几个表:
QRTZ_TRIGGERS 存放Trigger(包括SIMPLE_TRIGGERS和CRON_TRIGGERS)和jobDetail的对应关系
QRTZ_TRIGGER_LISTENERS
QRTZ_SIMPLE_TRIGGERS 存储简单触发器
QRTZ_SCHEDULER_STATE
QRTZ_PAUSED_TRIGGER_GRPS
QRTZ_LOCKS
QRTZ_JOB_LISTENERS
QRTZ_JOB_DETAILS 存储jobDetail
QRTZ_FIRED_TRIGGERS
QRTZ_CRON_TRIGGERS 存储复杂触发器CRON_TRIGGERS
QRTZ_CALENDARS
QRTZ_BLOB_TRIGGERS
七、把quartz集成到web应用中
1、根据quartz中提供的建表文档,建立数据库.
2、把如下quartz.properties文件放置到classes目录下.文件内容如下:
#============================================================================
# Configure Main Scheduler Properties
#============================================================================
#调度器名,无关紧要,名字任意定
org.quartz.scheduler.instanceName = ZXScheduler
org.quartz.scheduler.instanceId = AUTO
#============================================================================
# Configure ThreadPool 配置数据库连接池
#============================================================================
org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool
org.quartz.threadPool.threadCount = 12
org.quartz.threadPool.threadPriority = 5
#============================================================================
# Configure JobStore 配置做业存储方式
#============================================================================
#相当于扫描频率,如果系统基于秒级,应培植成1000,quartz默认为分级(60000)
org.quartz.jobStore.misfireThreshold = 1000
#org.quartz.jobStore.class = org.quartz.simpl.RAMJobStore
#如果设置内存,就不要设置clusterCheckinInterval等属性
#在这里自己控制事务
org.quartz.jobStore.class = org.quartz.impl.jdbcjobstore.JobStoreTX
org.quartz.jobStore.driverDelegateClass = org.quartz.impl.jdbcjobstore.MSSQLDelegate
org.quartz.jobStore.useProperties = false
#配置dataSource名
org.quartz.jobStore.dataSource = myDS
#表前缀
org.quartz.jobStore.tablePrefix = QRTZ_
org.quartz.jobStore.isClustered = false
#============================================================================
# Configure Datasources 配置数据库的连接,不用解释
#============================================================================
org.quartz.dataSource.myDS.driver = com.microsoft.jdbc.sqlserver.SQLServerDriver
org.quartz.dataSource.myDS.URL = jdbc:microsoft:sqlserver://127.0.0.1:1433;DatabaseName=quartzTest
org.quartz.dataSource.myDS.user = sa
org.quartz.dataSource.myDS.password = sa
org.quartz.dataSource.myDS.maxConnections = 5
3、配置web.xml,启动quartz的初试化类,添加初始化servlet
<servlet>
<servlet-name>QuartzInitializer</servlet-name>
<servlet-class>org.quartz.ee.servlet.QuartzInitializerServlet</servlet-class>
<init-param>
<param-name>shutdown-on-unload</param-name>
<param-value>true</param-value>
</init-param>
<init-param>
<param-name>config-file</param-name>
<param-value>quartz.properties</param-value>
</init-param>
<load-on-startup>2</load-on-startup>
</servlet>
4、系统配置完毕。
八、构造cron触发器(个人翻译,英文不好,莫见笑)
cron 触发器规范:
Seconds Minutes Hours Day-of-month Month Day-of-Week Year
秒 分 时 天 月 周 年
Seconds 0-59 , - * /
Minutes 0-59 , - * /
Hours 0-23 , - * /
Day-of-month 1-31 , - * ? / L C
Month 1-12 or JAN-DEC , - * /
Day-of-Week 1-7 or SUN-SAT , - * ? / L C #
Year (Optional) empty, 1970-2099 , - * /
关于字符串的设置(在cron expression中所有字符不区分大小写):
The '*' character is used to specify all values. For example, "*" in the minute field means "every minute".
"*"字符被用来指定所有的值,例如,"*"在分钟字段时表示每一分钟
The '?' character is allowed for the day-of-month and day-of-week fields. It is used to specify 'no specific value'. This is useful when you need to specify something in one of the two fileds, but not the other. See the examples below for clarification.
"?"字符在天和周字段中使用。表示没有指定值,天和周字段指定一个,但不能两个都指定为"?"
The '-' character is used to specify ranges For example "10-12" in the hour field means "the hours 10, 11 and 12".
'-'字符被用来设置范围,比如"10-12"在小时字段的意义为"10点,11点,12点"
The ',' character is used to specify additional values. For example "MON,WED,FRI" in the day-of-week field means "the days Monday, Wednesday, and Friday".
','字符被用来设置添加的值,例如在周字段设置"MON,WED,FRI"的意义即为:在周一、周三、周五激活
The '/' character is used to specify increments. For example "0/15" in the seconds field means "the seconds 0, 15, 30, and 45". And "5/15" in the seconds field means "the seconds 5, 20, 35, and 50". You can also specify '/' after the '*' character - in this case '*' is equivalent to having '0' before the '/'.
'/'字符被用来设置增量。例如秒字段设置"0/15"的意思为从0开始,每15秒触发,即在0、15、30、45秒触发,秒字段设置"5/15"的意思 为,从5开始,第15秒触发,即在5、20、35、50秒触发.你还可以在'*'后面使用'/'字符,在这种情况下'*'与字符'0'意义相同。
The '#' character is allowed for the day-of-week field. This character is used to specify "the nth" XXX day of the month. For example, the value of "6#3" in the day-of-week field means the third Friday of the month (day 6 = Friday and "#3" = the 3rd one in the month). Other examples: "2#1" = the first Monday of the month and "4#5" = the fifth Wednesday of the month. Note that if you specify "#5" and there is not 5 of the given day-of-week in the month, then no firing will occur that month.
'#'被用在周字段。它用来指定第几个周几中激活。如:"6#3"-->月的第三个周五;"2#1"-->月的第一个周一;"4#5"-- >月的第五个周三。要注意,如果要使用#后面跟5,但当月并没有第五周相应的周天,那么job将不被执行(激活);
The 'C' character is allowed for the day-of-month and day-of-week fields. This character is short-hand for "calendar". This means values are calculated against the associated calendar, if any. If no calendar is associated, then it is equivalent to having an all-inclusive calendar. A value of "5C" in the day-of-month field means "the first day included by the calendar on or after the 5th". A value of "1C" in the day-of-week field means "the first day included by the calendar on or after sunday".
Support for the features described for the 'C' character is not complete
'C'被用在天和周字段中,'C'是'calendar'的缩写.(不太明白,关于日历的支持还不完善)
Support for specifying both a day-of-week and a day-of-month value is not complete (you'll need to use the '?' character in on of these fields).
同时在周、天中使用'?'还不完善,目前只在两者中使用一个。
Pay attention to the effects of '?' and '*' in the day-of-week and day-of-month fields!
要注意'?'和'*'在周和天字段带来的影响。
注意以下例子:
1、"0 15 10 * * 6L 2002-2005" 在2002至2005年的每月每天的10:15触发。
2、"0 15 10 ? * 6L 2002-2005" 在2002至2005年的每月的最后一个周五触发。
1中*表示每天,覆盖了6L(最后一个周五)
一、关于job:
用Quartz的行话讲,作业是一个执行任务的简单Java类。任务可以是任何Java代码。只需你实现org.quartz.Job接口并且在出现严重 错误情况下抛出JobExecutionException异常即可。Job接口包含唯一的一个方法execute(),作业从这里开始执行。一旦实现了 Job接口和execute()方法,当Quartz确定该是作业运行的时候,它将调用你的作业。Execute()方法内就完全是你要做的事情。要注 意,自己实现job时必须有一个public 的无参数的构造方法.对于job,大多数情况下都要依赖于某些具体的条件,这时,就要用到JobDataMap了。JobDataMap是Map的一个子 类,获取时很简单,直接用get方法就ok了,基于参数,我们就可以定制不同的job任务了。下面是一个简单的job,用来列举出所有的参数并且获得参数 名为name的值.
public class HelloJob implements Job {
private static Log _log = LogFactory.getLog(HelloJob.class);
public HelloJob() {
}
public void execute(JobExecutionContext context)
throws JobExecutionException {
JobDataMap jobDataMap = context.getJobDetail().getJobDataMap();
_log.info("要执行的参数如下:");
Iterator i = jobDataMap.entrySet().iterator();
while(i.hasNext()) {
Map.Entry me = (Map.Entry)i.next();
_log.info(me.getKey() + ": "+me.getValue());
}
_log.info("U Are Welcome:"+jobDataMap.get("name"));
}
}
二、关于jobdetail:
Quartz并不存储一个真正的Job实例,相反的,它通过jobdetail来定义job,并指定job的name和group,在一个调度器 (Scheduler)中,name和group是唯一被定义的,一个触发器(trigger)只能指定一个job,但多个触发器可以指定同一个job.
Scheduler的作用就是调用任务,在指定的时间执行指定的任务。主要方法如下:
scheduleJob方法:
scheduleJob(JobDetail jobDetail, Trigger trigger):把jobDetail添加到调度器中,并指定触发器trigger.在这里要注意,在同一个调度器中,jobDetail的name和 group是唯一的;Trigger的name和group也必须是唯一的。如果在trigger中指定job的name,则该name必须和 jobDetail的name保持一致,否则会抛出异常。
scheduleJob(Trigger trigger):指定的trigger中必须包含jobdetai的name.以便于让quartz知道要执行的任务,如果指定的jobdetail的 name不在调度器中的任务列表中,则会抛出JobPersistenceException异常。
deleteJob(String jobName,String groupName)方法:
删除指定的job,并且删除所有相关联的触发器。(Delete the identified Job from the Scheduler - and any associated Triggers.)
四、关于作业存储
Quartz提供两种基本作业存储类型。
第一种类型叫做RAMJobStore,它利用通常的内存来持久化调度程序信息。这种作业存储类型最容易配置、构造和运行。对许多应用来说,这种作业存储 已经足够了。然而,因为调度程序信息是存储在被分配给JVM的内存里面,所以,当应用程序停止运行时,所有调度信息将被丢失。
第二种类型称为JDBC作业存储。Quartz提供两种不同的实现,但两种实现一般都需要JDBC驱动程序和后台数据库来持久化调度程序信息。这两种类型 的不同在于你是否想要控制数据库事务或这释放控制给应用服务器例如BEA's WebLogic或Jboss。(这类似于J2EE领域中,Bean管理的事务和和容器管理事务之间的区别)这两种JDBC作业存储是:
· JobStoreTX:当你想要控制事务或工作在非应用服务器环境中是使用 (注:自己控制事务)。
· JobStoreCMT:当你工作在应用服务器环境中和想要容器控制事务时使用 (web服务器控制事务)。
五、关于触发器
Quartz中的触发器用来告诉调度程序作业什么时候触发。框架提供了一把触发器类型,但两个最常用的是SimpleTrigger和CronTrigger。SimpleTrigger为需要简单打火调度而设计。
典型地,如果你需要在给定的时间和重复次数或者两次打火之间等待的秒数打火一个作业,那么SimpleTrigger适合你。
另一方面,如果你有许多复杂的作业调度,那么或许需要CronTrigger。
CronTrigger很强大,使用复杂的时间判断来使用,效果很好。
六、关于Quartz中的几个表:
QRTZ_TRIGGERS 存放Trigger(包括SIMPLE_TRIGGERS和CRON_TRIGGERS)和jobDetail的对应关系
QRTZ_TRIGGER_LISTENERS
QRTZ_SIMPLE_TRIGGERS 存储简单触发器
QRTZ_SCHEDULER_STATE
QRTZ_PAUSED_TRIGGER_GRPS
QRTZ_LOCKS
QRTZ_JOB_LISTENERS
QRTZ_JOB_DETAILS 存储jobDetail
QRTZ_FIRED_TRIGGERS
QRTZ_CRON_TRIGGERS 存储复杂触发器CRON_TRIGGERS
QRTZ_CALENDARS
QRTZ_BLOB_TRIGGERS
七、把quartz集成到web应用中
1、根据quartz中提供的建表文档,建立数据库.
2、把如下quartz.properties文件放置到classes目录下.文件内容如下:
#============================================================================
# Configure Main Scheduler Properties
#============================================================================
#调度器名,无关紧要,名字任意定
org.quartz.scheduler.instanceName = ZXScheduler
org.quartz.scheduler.instanceId = AUTO
#============================================================================
# Configure ThreadPool 配置数据库连接池
#============================================================================
org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool
org.quartz.threadPool.threadCount = 12
org.quartz.threadPool.threadPriority = 5
#============================================================================
# Configure JobStore 配置做业存储方式
#============================================================================
#相当于扫描频率,如果系统基于秒级,应培植成1000,quartz默认为分级(60000)
org.quartz.jobStore.misfireThreshold = 1000
#org.quartz.jobStore.class = org.quartz.simpl.RAMJobStore
#如果设置内存,就不要设置clusterCheckinInterval等属性
#在这里自己控制事务
org.quartz.jobStore.class = org.quartz.impl.jdbcjobstore.JobStoreTX
org.quartz.jobStore.driverDelegateClass = org.quartz.impl.jdbcjobstore.MSSQLDelegate
org.quartz.jobStore.useProperties = false
#配置dataSource名
org.quartz.jobStore.dataSource = myDS
#表前缀
org.quartz.jobStore.tablePrefix = QRTZ_
org.quartz.jobStore.isClustered = false
#============================================================================
# Configure Datasources 配置数据库的连接,不用解释
#============================================================================
org.quartz.dataSource.myDS.driver = com.microsoft.jdbc.sqlserver.SQLServerDriver
org.quartz.dataSource.myDS.URL = jdbc:microsoft:sqlserver://127.0.0.1:1433;DatabaseName=quartzTest
org.quartz.dataSource.myDS.user = sa
org.quartz.dataSource.myDS.password = sa
org.quartz.dataSource.myDS.maxConnections = 5
3、配置web.xml,启动quartz的初试化类,添加初始化servlet
<servlet>
<servlet-name>QuartzInitializer</servlet-name>
<servlet-class>org.quartz.ee.servlet.QuartzInitializerServlet</servlet-class>
<init-param>
<param-name>shutdown-on-unload</param-name>
<param-value>true</param-value>
</init-param>
<init-param>
<param-name>config-file</param-name>
<param-value>quartz.properties</param-value>
</init-param>
<load-on-startup>2</load-on-startup>
</servlet>
4、系统配置完毕。
八、构造cron触发器(个人翻译,英文不好,莫见笑)
cron 触发器规范:
Seconds Minutes Hours Day-of-month Month Day-of-Week Year
秒 分 时 天 月 周 年
Seconds 0-59 , - * /
Minutes 0-59 , - * /
Hours 0-23 , - * /
Day-of-month 1-31 , - * ? / L C
Month 1-12 or JAN-DEC , - * /
Day-of-Week 1-7 or SUN-SAT , - * ? / L C #
Year (Optional) empty, 1970-2099 , - * /
关于字符串的设置(在cron expression中所有字符不区分大小写):
The '*' character is used to specify all values. For example, "*" in the minute field means "every minute".
"*"字符被用来指定所有的值,例如,"*"在分钟字段时表示每一分钟
The '?' character is allowed for the day-of-month and day-of-week fields. It is used to specify 'no specific value'. This is useful when you need to specify something in one of the two fileds, but not the other. See the examples below for clarification.
"?"字符在天和周字段中使用。表示没有指定值,天和周字段指定一个,但不能两个都指定为"?"
The '-' character is used to specify ranges For example "10-12" in the hour field means "the hours 10, 11 and 12".
'-'字符被用来设置范围,比如"10-12"在小时字段的意义为"10点,11点,12点"
The ',' character is used to specify additional values. For example "MON,WED,FRI" in the day-of-week field means "the days Monday, Wednesday, and Friday".
','字符被用来设置添加的值,例如在周字段设置"MON,WED,FRI"的意义即为:在周一、周三、周五激活
The '/' character is used to specify increments. For example "0/15" in the seconds field means "the seconds 0, 15, 30, and 45". And "5/15" in the seconds field means "the seconds 5, 20, 35, and 50". You can also specify '/' after the '*' character - in this case '*' is equivalent to having '0' before the '/'.
'/'字符被用来设置增量。例如秒字段设置"0/15"的意思为从0开始,每15秒触发,即在0、15、30、45秒触发,秒字段设置"5/15"的意思 为,从5开始,第15秒触发,即在5、20、35、50秒触发.你还可以在'*'后面使用'/'字符,在这种情况下'*'与字符'0'意义相同。
The '#' character is allowed for the day-of-week field. This character is used to specify "the nth" XXX day of the month. For example, the value of "6#3" in the day-of-week field means the third Friday of the month (day 6 = Friday and "#3" = the 3rd one in the month). Other examples: "2#1" = the first Monday of the month and "4#5" = the fifth Wednesday of the month. Note that if you specify "#5" and there is not 5 of the given day-of-week in the month, then no firing will occur that month.
'#'被用在周字段。它用来指定第几个周几中激活。如:"6#3"-->月的第三个周五;"2#1"-->月的第一个周一;"4#5"-- >月的第五个周三。要注意,如果要使用#后面跟5,但当月并没有第五周相应的周天,那么job将不被执行(激活);
The 'C' character is allowed for the day-of-month and day-of-week fields. This character is short-hand for "calendar". This means values are calculated against the associated calendar, if any. If no calendar is associated, then it is equivalent to having an all-inclusive calendar. A value of "5C" in the day-of-month field means "the first day included by the calendar on or after the 5th". A value of "1C" in the day-of-week field means "the first day included by the calendar on or after sunday".
Support for the features described for the 'C' character is not complete
'C'被用在天和周字段中,'C'是'calendar'的缩写.(不太明白,关于日历的支持还不完善)
Support for specifying both a day-of-week and a day-of-month value is not complete (you'll need to use the '?' character in on of these fields).
同时在周、天中使用'?'还不完善,目前只在两者中使用一个。
Pay attention to the effects of '?' and '*' in the day-of-week and day-of-month fields!
要注意'?'和'*'在周和天字段带来的影响。
注意以下例子:
1、"0 15 10 * * 6L 2002-2005" 在2002至2005年的每月每天的10:15触发。
2、"0 15 10 ? * 6L 2002-2005" 在2002至2005年的每月的最后一个周五触发。
1中*表示每天,覆盖了6L(最后一个周五)
发表评论
-
JVM分析
2016-06-16 13:24 462在这里对linux下、sun(oracle) JDK的线程 ... -
新版apache HttpClient调用http接口
2016-03-29 10:49 1226新项目中使用新版的apache HttpClient调用h ... -
IP地址与数字相互转换
2015-12-03 11:50 1009/** * ip地址转成整数. ... -
com.sun.xml.stream.ZephyrParserFactory not found
2015-10-12 14:52 2190org.springframework.beans.fact ... -
HTTP - 304实现
2015-09-30 09:21 1095最近公司做了一个CMS项目,其中涉及到图片上传后页面展现, ... -
java mail 发送邮件
2015-07-01 17:51 5081. 邮件发送封装类 import java.util.P ... -
银行卡验证
2015-06-05 16:06 1331现行 16 位银联卡现行卡号开头 6 位是 622126~6 ... -
java读取classpath文件
2015-02-26 10:05 819ClassLoader 提供了两个方法用于从装载的类路径中取 ... -
Java中如何获取spring中配置的properties属性文件内容
2015-02-13 15:27 1911String host = (String) Custom ... -
CXF动态客户端No operation was found with the name问题
2015-01-21 12:59 1193如果WebService发布时,接口和实现类指定的names ... -
RestTemplate设置代理
2015-01-16 10:35 4672RestTemplate restTemplate = ne ... -
java字符串压缩
2015-01-14 13:49 2214采用jdk自带的gzip和zip方法进行压缩。并用apac ... -
遍历JSONArray及JSONObject
2015-01-14 12:59 2776String json = "{''data' ... -
java 已知一个Date(),获取前一天和后一天
2014-11-10 16:36 1842import java.text.ParseExceptio ... -
遍历Collection
2014-07-29 13:37 1009一、Map的遍历 import java.util.Has ... -
Service里直接写iBATIS
2014-03-05 15:08 710以前使用iBATIS时,DAO类,需要先定义一个接口,再定义 ... -
EntrySet比KeySet效率高
2014-03-05 14:57 986import java.util.Calendar; im ... -
Java跳出for循环
2014-02-21 12:44 1191a: for (Person person : ... -
Dom4j将document对象转换成String
2013-08-01 10:30 2778Dom4j将document对象转换成String: do ... -
IO中用ByteArrayOutputStream解决乱码问题
2013-07-31 20:48 7788IO中另外一种防止乱码的方法:使用ByteArrayOutp ...
相关推荐
OpenSymphony 的Quartz提供了一个比较完美的任务调度解决方案。 Quartz 是个开源的作业调度框架,为在 Java 应用程序中进行作业调度提供了简单却强大的机制。 Quartz中有两个基本概念:作业和触发器。作业是...
本文将深入解析 Quartz.NET 的配置文件,尤其是 `quartz.config` 和 `quartz_jobs.xml` 文件。 ### 1. Quartz.NET 配置文件 (`quartz.config`) `quartz.config` 文件是 Quartz.NET 的主要配置源,它使用基于 XML 的...
Spring Boot与Quartz的结合提供了便捷的配置方式,特别是通过YAML(YAML Ain't Markup Language)配置文件,使得配置更加直观和灵活。以下将详细介绍如何在Spring Boot应用中使用YAML文件配置Quartz定时任务,以及...
二、配置文件详解 Quartz的配置文件通常为`quartz.properties`,它定义了Scheduler的属性和Job、Trigger的细节。以下是一些关键配置项: 1. `org.quartz.scheduler.instanceName`: 调度器的唯一标识,用于区分多个...
### quartz时间配置详解 #### 一、Cron表达式的构成与理解 Quartz是一个功能强大的开源作业调度框架,被广泛应用于各种应用场景中进行任务的定时调度。Cron表达式是Quartz中定义作业执行时间的一种方式,它由六个...
接下来是在Spring配置文件中对Quartz进行配置。以下是配置示例: ```xml <!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd"> <!-- 要调用的工作类 --> ...
在Maven或Gradle的配置文件中,我们需要引入Quartz库以及Spring对Quartz的支持库。这些库将包含所有必要的类和接口,如`Scheduler`, `Job`, `Trigger`等,用于定义和管理定时任务。 接下来,配置Quartz。在Spring的...
在配置任务时,需要定义一个任务类,例如 `MyJob`,并在 Spring 配置文件中定义该任务类的 Bean。 ```xml <bean id="myJob" class="cn.test.manager.job.MyJob"></bean> ``` ### 2.3 整合 Spring 在整合 Spring ...
二、Quartz配置 Quartz的配置通常通过`quartz.properties`文件完成,主要包括以下内容: 1. 调度器实例名 2. 选择合适的JobStore类型 3. 数据源配置(如果使用数据库存储) 4. 是否启用集群模式 5. 启动延迟和检查...
SpringBoot提供了对Quartz的自动配置,只需添加相关依赖,配置文件中设置一些属性,即可快速启动定时任务服务。 **8. 管理界面** 为了方便管理和监控定时任务,可以开发一个Web界面,利用Quartz提供的API查询Job和...
2. application.properties:这是Grails应用的配置文件,可以在这里设置Quartz的相关配置,如数据库连接、调度策略等。 3. plugin.xml:插件的XML配置文件,用于描述插件的元数据,包括插件的名称、版本、作者等...
在 Spring 的配置文件(如 `applicationContext.xml`)中,我们需要引入 Quartz 的配置,并声明一个 `SchedulerFactoryBean` 来实例化和配置 Quartz Scheduler。这通常包括定义数据源、JobDetail 和 Trigger。 2. ...
Quartz 动态调度详解 Quartz 动态调度是指在 Java 应用程序中使用 Quartz 框架来实现任务调度的功能。Quartz 是一个 opensource 的任务调度框架,提供了强大的任务调度功能,可以满足不同的业务需求。 Quartz 动态...
在这个案例中,我们需要理解SpringBoot的启动流程、配置文件(application.properties或.yml)的使用,以及如何创建SpringBoot应用。 2. **Quartz调度器**:Quartz是Java平台上的任务调度库,可以定义作业(Job)和...
**Android Studio下的Quartz工程详解** Quartz是一个开源的作业调度框架,广泛应用于Java环境中的任务调度。在Android Studio中使用Quartz,可以为应用程序添加定时执行的任务功能,例如定期发送通知、更新数据或者...
Quartz.NET支持多种数据库,如MySQL、Oracle、SQL Server等,这些脚本有助于在不同的数据库系统中配置和初始化Quartz.NET。 3. `Quartz.build`:这可能是构建脚本,如MSBuild或NAnt,用于自动化构建和测试Quartz...
- 下载和安装:初学者可以下载Quartz的JAR文件,并将其添加到项目的类路径中。然后通过配置属性文件来设置调度器。 - 示例应用程序:Quartz提供了一个示例应用程序,帮助初学者快速上手,通过实际的代码示例学习...
### Spring 多个定时任务 Quartz 配置详解 #### 一、Spring与Quartz集成概述 Spring 是一款轻量级的 Java 开发框架,而 Quartz 是一个强大的作业调度框架。两者结合可以方便地实现定时任务的功能。通过 Spring 来...
3. **src/main/resources**:资源文件目录,可能有 Spring 的配置文件(如 applicationContext.xml)以及 Quartz 的配置文件(如 quartz.properties)。 4. **src/test**:测试目录,可能包含单元测试或集成测试代码...
- 在配置文件中启用定时任务功能。 ```xml <!-- springmvc-servlet.xml --> * * ?"/> ``` 以上介绍了Quartz任务调度的基础概念、工作原理以及如何使用Quartz框架进行任务调度。通过Quartz框架的强大...