作用:
客户开发人员可以利用计划任务接口定时执行一段自己定义的操作,比如在两个数据源之间交换数据。
Ecology提供两种计划任务接口:
1. IntervalJob接口,此接口每隔一段时间执行一次(自己定义间隔时间)
2. CronJob接口,此接口在指定的时间点执行(自己定义时间点)
定义计划任务的方法是在ecology安装目录/WEB-INF/service/schedule.xml中声明:
<service-point id=”job1″ interface=”weaver.interfaces.schedule.IntervalJob”>
<invoke-factory>
<construct class=”weaver.interfaces.schedule.BaseIntervalJob”>
<set-service property=”ds” service-id=”local”/>
<set property=”second” value=”60″/>
</construct>
</invoke-factory>
</service-point>
上面的声明定义了一个名为job1的IntervalJob,该接口中的方法execute()将会每60秒执行一次。同时把前面定义的local数据源注入到了接口中,这样的话就可以在execute()中读写local数据源。我们也可以注入两个数据源到接口中,这样就可以在两个数据源之间交换数据:
<service-point id=”job2″ interface=”weaver.interfaces.schedule.IntervalJob”>
<invoke-factory>
<construct class=”weaver.interfaces.schedule.BaseIntervalJob”>
<set-service property=”ds” service-id=”local”/>
<set-service property=”ds1″ service-id=”msds”/>
<set property=”second” value=”60″/>
</construct>
</invoke-factory>
</service-point>
声明一个CronJob的方法和IntervalJob类似,在ecology安装目录/WEB-INF/service/schedule.xml中声明:
<service-point id=”job3″ interface=”weaver.interfaces.schedule.CronJob”>
<invoke-factory>
<construct class=”weaver.interfaces.schedule.BaseCronJob”>
<set-service property=”ds” service-id=”local”/>
<set-service property=”ds1″ service-id=”msds”/>
<set property=”cronExpr” value=”0 44 12 ? * MON-FRI”/>
</construct>
</invoke-factory>
</service-point>
上面的声明定义了一个周一到周五12:44执行的计划任务。什么时候执行计划任务由cronExpr表达式决定。
一个cron表达式有至少6个有空格分隔的时间元素,按顺序依次为:
秒(0~59)
分钟(0~59)
小时(0~23)
天(月)(0~31,但是你需要考虑你月的天数)
月(0~11)
天(星期)(1~7 1=SUN 或 SUN,MON,TUE,WED,THU,FRI,SAT)
0 0 10,14,16 * * ? 每天上午10点,下午2点,4点
0 0/30 9-17 * * ? 朝九晚五工作时间内每半小时
0 0 12 ? * WED 表示每个星期三中午12点
“0 0 12 * * ?” 每天中午12点触发
“0 15 10 ? * *” 每天上午10:15触发
“0 15 10 * * ?” 每天上午10:15触发
“0 * 14 * * ?” 在每天下午2点到下午2:59期间的每1分钟触发
“0 0/5 14 * * ?” 在每天下午2点到下午2:55期间的每5分钟触发
“0 0/5 14,18 * * ” 在每天下午2点到2:55期间和下午6点到6:55期间的每5分钟触发
“0 0-5 14 * * ?” 在每天下午2点到下午2:05期间的每1分钟触发
“0 10,44 14 ? 3 WED” 每年三月的星期三的下午2:10和2:44触发
“0 15 10 ? * MON-FRI” 周一至周五的上午10:15触发
“0 15 10 15 * ?” 每月15日上午10:15触发
“0 15 10 L * ?” 每月最后一日的上午10:15触发
“0 15 10 ? * 6L” 每月的最后一个星期五上午10:15触发
“0 15 10 ? * 6#3” 每月的第三个星期五上午10:15触发
有些子表达式能包含一些范围或列表
例如:子表达式(天(星期))可以为 “MON-FRI”,“MON,WED,FRI”,“MON-WED,SAT”
“*”字符代表所有可能的值
因此,“*”在子表达式(月)里表示每个月的含义,“*”在子表达式(天(星期))表示星期的每一天
“/”字符用来指定数值的增量
例如:在子表达式(分钟)里的“0/15”表示从第0分钟开始,每15分钟
在子表达式(分钟)里的“3/20”表示从第3分钟开始,每20分钟(它和“3,23,43”)的含义一样
“?”字符仅被用于天(月)和天(星期)两个子表达式,表示不指定值
当2个子表达式其中之一被指定了值以后,为了避免冲突,需要将另一个子表达式的值设为“?”
注意,上文中的weaver.interfaces.schedule.BaseIntervalJob和weaver.interfaces.schedule.BaseIntervalJob是ecology提供的默认接口实现,它们的execute()是空的,不做任何操作。客户开发人员如果要使用计划任务接口的话,必需继承weaver.interfaces.schedule.BaseIntervalJob或weaver.interfaces.schedule.BaseIntervalJob,用自己的业务逻辑覆盖它们的execute().
举个简单的例子,我需要ecology系统每隔一小时统计一下系统人数并输出到控制台,步骤如下
1. 编写自己的计划任务实现
import weaver.interfaces.schedule.BaseIntervalJob;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
/**
* IntervalJob示范代码,集成BaseIntervalJob,用自己的业务逻辑覆盖了execute()方法
*/
public class MyIntervalJob extends BaseIntervalJob {
public void execute() {
//从数据源中获取连接
Connection conn = getDs().getConnection();
try {
//通过jdbc获取人数
PreparedStatement s = conn.prepareStatement(“select count(*) as amount from hrmresource”);
ResultSet rs = s.executeQuery();
rs.next();
String amount = rs.getString(“amount”);
//输出到控制台
System.out.println(“人数:” + amount);
//关闭记录集
rs.close();
//关闭statement
s.close();
} catch (Exception e) {
getLog().error(e);
} finally {
try {
//关闭连接
conn.close();
} catch (Exception e) {
getLog().error(e);
}
}
}
}
3. 在schedule.xml中声明
<service-point id=”job3″ interface=”weaver.interfaces.schedule.IntervalJob”>
<invoke-factory>
<construct class=”MyIntervalJob”>
<set-service property=”ds” service-id=”local”/>
<set property=”second” value=”3600″/>
</construct>
</invoke-factory>
</service-point>
可以用类似的方法实现自己的cronJob,本文不再赘述。
转载请注明:赫非域 » Ecology定时任务接口