JFinal定时任务调度问题

由于最近的项目是非Maven项目实现定时任务调度,通过上网查找得知JFinal-ext的jar封装了对Quartz定时器的调用,但是按照操作进行调试,出现找不到com.jfinal.log.Log类的错误信息,后来得知ext没有更新,不过很感谢@JFinal的帮助,用邮箱给我解决方案。下面为解决问题的步骤:

下面链接为项目中需要的jar包和Cron4jPlugin、ITask:http://pan.baidu.com/s/1eSLm9to

步骤如下:

  1. 首先需要项目的jar包,将cron4j-2.2.5.jar放在项目中lib目录下

  2. 将Cron4jPlugin和接口ITask放到项目中,我放在继承至JFinalConfig的类的同包下

  3. 在Cron4j配置文件中设置如下,此文件起名为task.properties,文件中newCron=* * * * *

    表达每分钟执行一次。代码如下:

  4. cron4j=newCron, registerCron, foreignExchangeCron
    #newCron 
    newCron.cron=* * * * *
    newCron.class=cn.cyansoft.xine.task.NewTask
    newCron.enable=true
    #registerCron
    registerCron.cron=* * * * *
    registerCron.class=cn.cyansoft.xine.task.RegisterTask
    registerCron.enable=true
    #foreignExchange
    foreignExchangeCron.cron=* * * * *
    foreignExchangeCron.class=cn.cyansoft.xine.task.ForeignExchangeTask
    foreignExchangeCron.enable=true
  5. 在继承至JFinalConfig类中的configPlugin,加载配置


  6. public void configPlugin(Plugins me) {
    
    me.add(new Cron4jPlugin(PropKit.use("task.properties")));
    
    }
  7. 在任务类中实现ITask接口,在run中写定时任务

    让自己的Task实现ITask杰克,或者实现Runable接口也可以。

    假定这个MyTask在com.xxx包下        

  8. public class MyTask implements ITask {
       public void run() {
          // 这里放被执行的调试任务代码
       }
       
       public void stop() {
         // 这里的代码会在 task 被关闭前调用
       }
    }
  9. 到以上为止能够实现定时调度任务,由于我的项目是Jfinal-weixin项目,定时给部分用户发送客服消息,出现如下错误

    http://www.jfinal.com/feedback/138,已反馈并已解决在此反馈中。

    将我解决的方案分享一下,希望能帮到像我一样遇到这样问题的伙伴们。

补充

一、关于定时器配置文件(task.properties)的参数解释:

以上配置中 cron4j 是入口,后面的 newCron 是任务名称,可以随便起名,这个例子中起的名字是 "newCron"
一旦起了这个名称,后面的配置就是以这个 "newCron" 打头,例如上面的 newCron.cron、newCron.class等等
newCron.cron=.... 配置调试表达式,具体的含义在 Cron4jPlugin 源代码中有说明,切记:cron 表达式只有五个部分,
taskName.class=... 配置任务的实现类,指向最前面的 MyTask 类,注意类的路径配置正确
taskName.enable=... 配置该任务是否有效,如果为 false,则不会被处理,相当于一个开关变量,这个配置可以省略,省略时默认值为 true
再说明一点,假定 cron4j=abc 这么配置,那么后面的三个配置如下:
abc.cron=0 * * * *
abc.class=com.xxx.MyTask
abc.enable=true
最后再被被一点,cron4j 可以同时配置多个任务,以逗号分隔,以下代码同时配置了两个任务
cron4j=taskAaa, taskBbb
taskAaa.cron=0 * * * *
taskAaa.class=com.xxx.TaskOne
taskAaa.enable=true
taskBbb.cron=0 * * * *
taskBbb.class=com.xxx.OtherTask
taskBbb.enable=true

二、以下贴出 Cron4jPlugin 中的部分注释,说明了如何使用:

* cron 表达式由五部分组成:分 时 天 月 周
* 分 :从 0 到 59
* 时 :从 0 到 23
* 天 :从 1 到 31,字母 L 可以表示月的最后一天
* 月 :从 1 到 12,可以别名:jan", "feb", "mar", "apr", "may", "jun", "jul", "aug", "sep", "oct", "nov" and "dec"
* 周 :从 0 到 6,0 表示周日,6 表示周六,可以使用别名: "sun", "mon", "tue", "wed", "thu", "fri" and "sat"
*
* 数字 n:表示一个具体的时间点,例如 5 * * * * 表示 5 分这个时间点时执行
* 逗号 , :表示指定多个数值,例如 3,5 * * * * 表示 3 和 5 分这两个时间点执行
* 减号 -:表示范围,例如 1-3 * * * * 表示 1 分、2 分再到 3 分这三个时间点执行
* 星号 *:表示每一个时间点,例如 * * * * * 表示每分钟执行
* 除号 /:表示指定一个值的增加幅度。例如 n/m表示从 n 开始,每次增加 m 的时间点执行

三、若是maven项目用户:

<dependency>
 <groupId>it.sauronsoftware.cron4j</groupId>
 <artifactId>cron4j</artifactId>
 <version>2.2.5</version>
</dependency>


评论区

学而精

2017-08-12 20:57

@JFinal 在吗 遇到问题了= =!

flower929

2017-08-21 12:27

@JFinal 好的,了解,谢谢

yyqq

2017-09-12 11:22

请问配置文件是直接放在src目录下吗

ts_wh

2017-09-15 11:09

@ts_wh 如果定时任务执行的时候断网了,过段时间网络又好了,那么定时任务还会执行吗

ts_wh

2017-09-15 11:10

定时任务正在执行,突然就断网了,过了几分钟网络又通了,那么定时任务还会继续执行吗

zz210891470

2017-09-26 09:32

public void stop() {
// 这里的代码会在 task 被关闭前调用
}
请问楼主关闭代码何时调用的到,关闭网页 或者session过期都无法调用,
如何在用户关闭网页的时候调用这个代码 或者还有什么更好的方式。

null

2017-10-31 16:59

这个任务可以动态添加吗

精彩飞扬

2017-11-09 14:02

@null 可以动态添加,在Cron4jPlugin方法提供了几个公有的addTask方法,例如:
Cron4jPlugin cron4jPlugin = new Cron4jPlugin();
cron4jPlugin.addTask("* * * * *", runnable, false, true);
me.add(cron4jPlugin);

精彩飞扬

2017-11-09 14:07

@zz210891470 一般处理后台定时任务,stop可以使用手动停止任务。与前端交互不多,如果想用的话,我认为可以使用反射获取相应任务的对象,调用stop方法,停止任务。

null

2017-11-28 09:51

qwerty111

2017-12-01 11:33

@JFinal 有没有简单易懂的jfinal定时任务配置的说明啊,最好是有定时操作数据库的那种

为杰沉沦

2018-01-10 09:51

这个定时器 为什么项目部署在linux系统的时候用不了 window系统可以

精彩飞扬

2018-01-17 12:22

@为杰沉沦 我的是好用的,你打印日志看看。

学习使我快乐

2018-03-05 15:03

@精彩飞扬 大神,我定时调用getModel方法,空指针。

学习使我快乐

2018-03-05 17:26

@jfinal 定时任务调度,request为null怎么解决?

齐天大圣_new

2018-03-27 18:13

@JFinal 报这个错是什么原因,按楼上分享的步骤来的java.lang.RuntimeException: java.lang.ClassNotFoundException: cn.cyansoft.xine.task.NewTask

JFinal

2018-03-27 18:15

@齐天大圣_new ClassNotFoundException 缺少 jar 包

JFinal

2018-03-27 18:31

@齐天大圣_new 你照抄了这个贴子中的配置,配置里头有 cn.cyansoft.xine.task.NewTask,你去掉它,或者改成你自己的即可

JFinal

2018-03-27 18:32

@齐天大圣_new 多看看 Cron4jPlugin 的配置文档

齐天大圣_new

2018-03-27 19:26

@JFinal @JFinal 我已经弄好了,刚才没看仔细,感谢感谢

齐天大圣_new

2018-03-28 14:00

@JFinal 好的,感谢解答

四宝

2018-06-28 20:18

@JFinal java.lang.IllegalArgumentException: taskA #???????????????????????????????á?.cron not found.这个报错是什么意思啊

年轻似水

2018-09-03 19:08

我想知道从开始执行和执行完毕用了多长时间怎么写

zcazj

2018-09-04 18:00

@JFinal 詹总,如果我想每天1点运行是不是就是 * 1 * * * 这么写?

JFinal

2018-09-04 20:51

@zcazj cron 表达式的五部分分别为:分钟、小时、天、月、周。

在写 cron 表达式时有个技巧,就是注意一下 “每” 这个表述,当你说 “每” 的时候,就是在相应的位置上使用星号 "*"

例如,你想每天 1 点运行,那么潜台词就是:你想每周、每月、每天、一点钟、零秒运行

位置与 cron 表达式一致就是:零秒、一点钟、每天、每月、每周

继续翻译成 cront 表达式就是:0 1 * * *

碰到每就用星号,没有表述的潜台词部分也要翻译出来,如上例中的每周、每月、每天

热门分享

扫码入社