Spring(一)Quartz任务调度

项目开发中经常有些功能,需要轮询处理业务逻辑。比如把待发送的邮件进行记录后,另外一个程式每隔5秒进行发送。.net中处理该种功能有以下几种方式:

1. 使用Windows Service编写一个Service服务,监控处理程式。

2. 使用MSMQ,把数据写入队列中,然后异步处理。

3. 某些场合可以使用Database的Job。

在java中可以使用以下几种方式:

1. OpenSymphony提供的Quartz,调度功能强大。

2. Sun从JDK1.3开始,提供的java.util.Timer和TimerTask,调度功能简单。

3. JDK 5.0,新增的java.util.concurrent包。

sping对上述调度的实现分别进行了封装。下面主要记录Spring使用Quartz。

在配置文件中使用quartz主要有4个步骤:

1. 建立java任务逻辑类后建立spring对应的bean。

2. 根据该bean,使用spring的基类,建立JobDetail。有两种方式:

a. 使用MethodInvokingJobDetailFactoryBean,通过targetObject属性直接指定任务类的spring bean和通过targetMethod属性指定类的方法即可。

b. 使用JobDetailBean,需要使用jobClass属性指定继承了QuartzJobBean接口的任务类,jobDataAsMap属性中的值可以被任务类在继承的方法中直接访问。

3. 建立JobDetail对应的Trigger,有SimpleTriggerBean和CronTriggerBean两种。指定任务运行的时间和周期

4. 使用SchedulerFactoryBean建立Schedule计划,指定对应的Trigger,可以指定多个。

以上涉及到的类都在org.springframework.scheduling.quartz包中。下面用实例说明其用法。

有一个java类quartzService编写任务逻辑,可以被MethodInvokingJobDetailFactoryBean类型的JobDetail直接使用

还有一个继承了QuartzJobBean并调用quartzService的类quartzJob,可以被JobDetailBean类型的JobDetail使用

下面看一下quartz的配置文件:

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值