spring中的quartz(定时器)的用法

版权声明:本文为博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/ruiguang21/article/details/90606088

quartz-all-2.1.1.jar

 

1.配置信息

    <!-- <bean class="org.cs.task.CreatorsTask"  init-method="creatorsTaskInit"></bean> -->
    <!-- 一个类里两个定时任务 配置你要定时加载的目标类    -->
    <bean id="autoJob" class="org.cs.task.CreatorsTask" />
    <!-- 定时任务1 -->
    <bean id="autoB2cJobDetail"    class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
        <!-- 指定任务类 -->
        <property name="targetObject" ref="autoJob" />
        <!-- 指定任务方法 -->
        <property name="targetMethod" value="creatorsTaskInits" />
        <property name="concurrent" value="false" />
    </bean>
    <!-- 定义时间间隔触发器
    org.springframework.scheduling.quartz.CronTriggerFactoryBean
    org.springframework.scheduling.quartz.CronTriggerBean
     -->
    <bean id="autoB2cJobDetailCronTrigger" class="org.springframework.scheduling.quartz.CronTriggerFactoryBean">
        <property name="jobDetail">
            <ref bean="autoB2cJobDetail" />
        </property>
        <!-- 0 0 1 1 * ? 
        */5 * * * * ?
        -->
        <property name="cronExpression">
            <value>0 0 1 1 * ? </value>
        </property>
    </bean>
    <!-- 启动定时器 -->
    <bean id="ssschedulerFactory" class="org.springframework.scheduling.quartz.SchedulerFactoryBean" lazy-init="false">
        
        <property name="triggers" ref="autoB2cJobDetailCronTrigger"></property>
    </bean>

 

 

从上面的配置可用看出,org.springframework.scheduling.quartz.CronTriggerBean允许你更精确地控制任务的运行时间,只需要设置其cronExpression属性。
一个cronExpression表达式有至少6个(也可能是7个)由空格分隔的时间元素。从左至右,这些元素的定义如下:
一、各域说明
字段域    秒    分    时    日    月    星期(7为周六)    年(可选)
取值范围    0-59    0-59    0-23    1-31    1-12或JAN–DEC    1-7或SUN–SAT    1970–2099
可用字符    , - * /    , - * /    , - * /    , - * ? / L W C    , - * /    , - * ? / L C #    , - * /
示例    例1    例2    例3    例4    例5    例6    例7
二、举例说明
例1:每隔5秒执行一次:*/5 * * * * ?

例2:每隔5分执行一次:0 */5 * * * ?
         在26分、29分、33分执行一次:0 26,29,33 * * * ?

例3:每天半夜12点30分执行一次:0 30 0 * * ? (注意日期域为0不是24)
         每天凌晨1点执行一次:0 0 1 * * ?
         每天上午10:15执行一次: 0 15 10 ? * * 或 0 15 10 * * ? 或 0 15 10 * * ? *
         每天中午十二点执行一次:0 0 12 * * ?
         每天14点到14:59分,每1分钟执行一次:0 * 14 * * ?
         每天14点到14:05分,每1分钟执行一次:0 0-5 14 * * ?
         每天14点到14:55分,每5分钟执行一次:0 0/5 14 * * ?
         每天14点到14:55分,和18点到18点55分,每5分钟执行一次:0 0/5 14,18 * * ?
         每天18点执行一次:0 0 18 * * ?
         每天18点、22点执行一次:0 0 18,22 * * ?
         每天7点到23点,每整点执行一次:0 0 7-23 * * ?
         每个整点执行一次:0 0 0/1 * * ?

例4:每月1号凌晨1点执行一次:0 0 1 1 * ?
         每月15号的10点15分执行一次:0 15 10 15 * ?
         每月的最后一天的10:15执行一次:0 15 10 L * ?

例5:每月最后一天23点执行一次:0 0 23 L * ?

例6:每周星期天凌晨1点执行一次:0 0 1 ? * L
         三月的每周三的14:10和14:44执行一次:0 10,44 14 ? 3 WED
         每个周一、周二、周三、周四、周五的10:15执行一次:0 15 10 ? * MON-FRI
         每月最后一个周五的10:15执行一次:0 15 10 ? * 6L


例7:2016年的每天早上10:15执行一次: 0 15 10 * * ? 2016

三、特殊字符说明
“,”字符:列出枚举值值。例如:0 26,29,33 * * * ?表示在26分、29分、33分执行一次。

“-”字符:指定一个值的范围。例如:0 0-5 14 * * ?表示每天从下午2点开始到2:05分结束,每1分钟执行一次

“*”字符:表示匹配该域的任意值,假如在Minutes域使用*, 即表示每分钟都会触发事件。 例如:0 * 14 * * ?表示每天从下午2点开始到2:59分结束,每1分钟执行一次

“/”字符:指定一个值的增加幅度。n/m表示从n开始,每次增加m。例如:*/5 * * * * ?表示每隔5秒执行一次

“L”字符:用在日表示一个月中的最后一天,用在周表示该周最后一个星期,也就是周日。例如:0 0 23 L * ?表示每月最后一天23点执行一次。

“W”字符:指定离给定日期最近的工作日(周一到周五)。例如:在字段月域里使用5W,如果5日是星期六,则将在最近的工作日:星期五,即4日触发。如果5日是星期天,则在6日(周一)触发;如果5日在星期一到星期五中的一天,则就在5日触发。另外一点,W的最近寻找不会跨过月份。

“LW”字符:这两个字符可以连用,表示在某个月最后一个工作日,即最后一个星期五。

“#”字符:表示该月第几个周X。例如:6#3表示该月第3个周五

“?”字符:表示不确定的值。只能用在“月”和“周”两个域。它也匹配域的任意值,但实际不会。因为“月”和“周”会相互影响。例如想在每月的20日触发调度,不管20日到底是星期几,则只能使用如下写法: 0 0 0 20 * ?, 其中最后一位只能用?,而不能使用*,如果使用*表示不管星期几都会触发,实际上并不是这样。

“C”字符:可用于“日”和“周几”字段,它是"calendar"的缩写。它表示为基于相关的日历所计算出的值(如果有的话)。如果没有关联的日历,那它等同于包含全部日历。“日”字段值为"5C"表示"日历中的第一天或者5号以后",“周几”字段值为"1C"则表示"日历中的第一天或者周日以后"。


 

展开阅读全文

求教SPRING(Quartz) 定时器问题

11-12

Exception in thread "main" org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'jobDetailBean' defined in class path resource [bean-config.xml]: Invocation of init method failed; nested exception is java.lang.NoSuchMethodError: org.apache.commons.collections.SetUtils.orderedSet(Ljava/util/Set;)Ljava/util/Set;rnCaused by: java.lang.NoSuchMethodError: org.apache.commons.collections.SetUtils.orderedSet(Ljava/util/Set;)Ljava/util/Set;rn at org.quartz.JobDetail.(JobDetail.java:85)rn at org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean.afterPropertiesSet(MethodInvokingJobDetailFactoryBean.java:188)rn at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java:1201)rn at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1171)rn at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:425)rn at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:251)rn at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:156)rn at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:248)rn at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:160)rn at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:284)rn at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:352)rn at org.springframework.context.support.ClassPathXmlApplicationContext.(ClassPathXmlApplicationContext.java:91)rn at org.springframework.context.support.ClassPathXmlApplicationContext.(ClassPathXmlApplicationContext.java:75)rn at org.springframework.context.support.ClassPathXmlApplicationContext.(ClassPathXmlApplicationContext.java:65)rn at onlyfun.caterpillar.QuartzDemo.main(QuartzDemo.java:14)rn 论坛

spring quartz 定时器 求大神

12-13

[ERROR] 2012-12-13 14:41:30 org.hibernate.util.JDBCExceptionReporter:78 - Cannot get a connection, pool error Timeout waiting for idle objectrn[ERROR] 2012-12-13 14:41:30 org.hibernate.util.JDBCExceptionReporter:78 - Cannot get a connection, pool error Timeout waiting for idle objectrn[ERROR] 2012-12-13 14:41:31 org.hibernate.util.JDBCExceptionReporter:78 - Cannot get a connection, pool error Timeout waiting for idle objectrn[ERROR] 2012-12-13 14:41:31 org.hibernate.util.JDBCExceptionReporter:78 - Cannot get a connection, pool error Timeout waiting for idle objectrn[ERROR] 2012-12-13 14:41:31 org.quartz.core.JobRunShell:211 - Job DEFAULT.attackCountEvent threw an unhandled Exception: rnorg.springframework.scheduling.quartz.JobMethodInvocationFailedException: Invocation of method 'executeInternal' on target class [class edu.xjtu.sei.skyeye.state.timer.AttackEventCountTimer] failed; nested exception is org.hibernate.exception.GenericJDBCException: Cannot open connectionrn at org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean$MethodInvokingJob.executeInternal(MethodInvokingJobDetailFactoryBean.java:269)rn at org.springframework.scheduling.quartz.QuartzJobBean.execute(QuartzJobBean.java:86)rn at org.quartz.core.JobRunShell.run(JobRunShell.java:202)rn at org.quartz.simpl.SimpleThreadPool$WorkerThread.run(SimpleThreadPool.java:525)rnCaused by: org.hibernate.exception.GenericJDBCException: Cannot open connectionrn at org.hibernate.exception.SQLStateConverter.handledNonSpecificException(SQLStateConverter.java:103)rn at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:91)rn at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:43)rn at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:29)rn at org.hibernate.jdbc.ConnectionManager.openConnection(ConnectionManager.java:424)rn at org.hibernate.jdbc.ConnectionManager.getConnection(ConnectionManager.java:144)rn at org.hibernate.jdbc.AbstractBatcher.prepareQueryStatement(AbstractBatcher.java:139)rn at org.hibernate.loader.Loader.prepareQueryStatement(Loader.java:1538)rn at org.hibernate.loader.Loader.doQuery(Loader.java:661)rn at org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:224)rn at org.hibernate.loader.Loader.doList(Loader.java:2211)rn at org.hibernate.loader.Loader.listIgnoreQueryCache(Loader.java:2095)rn at org.hibernate.loader.Loader.list(Loader.java:2090)rn at org.hibernate.loader.custom.CustomLoader.list(CustomLoader.java:289)rn at org.hibernate.impl.SessionImpl.listCustomQuery(SessionImpl.java:1695)rn at org.hibernate.impl.AbstractSessionImpl.list(AbstractSessionImpl.java:142)rn at org.hibernate.impl.SQLQueryImpl.list(SQLQueryImpl.java:152)rn at edu.xjtu.sei.skyeye.state.dao.AttackMontorDAO.checkCount(AttackMontorDAO.java:44)rn at edu.xjtu.sei.skyeye.state.timer.AttackEventCountTimer.executeInternal(AttackEventCountTimer.java:47)rn at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)rn at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)rn at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)rn at java.lang.reflect.Method.invoke(Method.java:597)rn at org.springframework.util.MethodInvoker.invoke(MethodInvoker.java:276)rn at org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean$MethodInvokingJob.executeInternal(MethodInvokingJobDetailFactoryBean.java:260)rn ... 3 morernCaused by: org.apache.commons.dbcp.SQLNestedException: Cannot get a connection, pool error Timeout waiting for idle objectrn at org.apache.commons.dbcp.PoolingDataSource.getConnection(PoolingDataSource.java:104)rn at org.apache.commons.dbcp.BasicDataSource.getConnection(BasicDataSource.java:880)rn at org.springframework.orm.hibernate3.LocalDataSourceConnectionProvider.getConnection(LocalDataSourceConnectionProvider.java:82)rn at org.hibernate.jdbc.ConnectionManager.openConnection(ConnectionManager.java:421)rn ... 23 morernrn在spring调用的时候刚开始都能执行,大概有2000多调数据,执行上大概10条左右就出现这种问题。不知道什么情况。求大神详解下。谢谢 论坛

没有更多推荐了,返回首页