2006年10月11日

Spring的任务调度服务实例讲解 {转}

Spring的任务调度服务实例讲解
记的以前在做一家人才招聘网站时遇到的一个问题,因为白天的流量非常大为了减轻网站的压力所以客户要求一些不是太急手的任务(如,给注册用户发送邮件、清理日常垃圾信息等等)都放在凌晨流量最小的时间段去执行,当时我们借助java.util.Timer来实现的。但是对于更加复杂的任务调度Timer就不太容易了,后来了解了Quartz(OpenSymphony的提供任务调务类库)可以大大弥补Timer的不足可以使开发者能够完成各种复杂的任务调度。Spring又对其提供了很好的支持使得开发者不用另外去学习这套全新的类库就能很方便的使用。
下面提供一个实例来讲解:

1. 首先把spring.jar包放到classpath下

2. 编辑spring配制文件,ApplicationContext.xml内容如下:

代码
						<
						?x
						ml
						version
						="
						1.0
						"
						encoding
						="
						UTF-8
						"
						?>
						
<! DOCTYPE beans PUBLIC " -//SPRING//DTD BEAN//EN " " spring-beans.dtd " >
< beans >
<!—要调度的对象-->
< bean id =" testQuarz " class =" springtimer.TestQuarz " />

<!--定义定时执行 testQuarz 这个bean中的sayHello()方法-->
<beanid="helloworldTask"class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
<propertyname="targetObject">
<refbean="testQuarz"/>
</property>
<property name="targetMethod">
<value>sayHello<
/value>
</property>
<
/bean>

<!--触发器的 bean的设置,在这里我们设置了我们要触发的jobDetail是哪个。这里我们定义了要触发的jobDetail是helloworldTask,即触发器去触发哪个bean ..并且我们还定义了触发的时间:每天 5 : 17 pm -->
< bean id =" cronTrigger "
class =" org.springframework.scheduling.quartz.CronTriggerBean ">
< property name =" jobDetail ">
< ref bean =" helloworldTask " />
</ property>
<property name="cronExpression">
<!-- 关键在配置此表达式 -->
<value>0 17 17 * * ?<
/ value >
</ property>
<
/ bean >

<!--管理触发器的总设置,管理我们的触发器列表,可以在 bean的list中放置多个触发器。
-->
< bean autowire =" no "
class =" org.springframework.scheduling.quartz.SchedulerFactoryBean ">
< property name =" triggers ">
< list >
< ref local =" cronTrigger " />
</ list>
<
/ property >
</ bean>
<
/ beans >

3.以下是被调度的类代码

代码
						package
						springtimer
						;
						

public class TestQuarz {

public void sayHello () {
System . out . println (" HelloWorld! ");
}
}

4,提供测试类

代码
						public
						class 
						TestHello
						{
						

public static void main ( String [] args ) {
/ / 只要加载配置文件就可以了,
ApplicationContextcontext=newClassPathXmlApplicationContext("ApplicationContext.xml");
System.out.println("*****完毕******");
}

5,Ok自已可以设置sping-config文件中<value>0 17 17 * * ?</value>的调度表达式,可以测试啦!

6, 下面简单的介绍一下cron expressions(调度表达式)

格式列表:

代码
						Field
						Name
						|
						Mandatory
						?
						|
						Allowed
						Values
						|
						Allowed
						Special
						Characters
						
Seconds | YES | 0 - 59 | , - * /
Minutes | YES | 0-59 | , - *
/
Hours | YES | 0 - 23 | , - * /
Day of month | YES | 1-31 | , - * ?
/ L W C
Month | YES | 1 - 12 or JAN - DEC | , - * /
Day of week | YES | 1-7 or SUN-SAT | , - * ?
/ L C #
Year | NO | empty , 1970 - 2099 | , - * /

至于详细的解释你一看例子就会明白

例子列表如下:
表达式 解释
0 0 12 * * ? 在每天中午12:00触发
0 15 10 ? * * 每天上午10:15 触发
0 15 10 * * ? 每天上午10:15 触发
0 15 10 * * ? * 每天上午10:15 触发
0 15 10 * * ? 2005 在2005年中的每天上午10:15 触发
0 * 14 * * ? 每天在下午2:00至2:59之间每分钟触发一次
0 0/5 14 * * ? 每天在下午2:00至2:59之间每5分钟触发一次
0 0/5 14,18 * * ? 每天在下午2:00至2:59和6:00至6:59之间的每5分钟触发一次
0 0-5 14 * * ? 每天在下午2:00至2:05之间每分钟触发一次
0 10,44 14 ? 3 WED 每三月份的星期三在下午2:00和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 ? * 6L 2002-2005 在2002, 2003, 2004 and 2005年的每个月的最后一个星期五的上午10:15触发
0 15 10 ? * 6#3 在每个月的第三个星期五的上午10:15触发
0 0 12 1/5 * ? 从每月的第一天起每过5天的中午12:00时触发
0 11 11 11 11 ? 在每个11月11日的上午11:11时触发.

posted @ 2006-10-11 14:53 圆月弯刀 阅读(396) | 评论 (0)编辑 收藏

Java中的几个小问题

1.关于“==”和“equals”,其中对引用型变量和简单类型是不同的
    (1) "==" 对简单类型来说,是比较值是否相等; 对于引用来说,是看二者是否指向同一个地址。
    (2) equals 不管对于什么类型都是比较值是否相等。

还要注意的是:当引用型变量没有通过关键字new 来申请变量时,它可能不会在堆里生成一个新的变量,而是到栈中找一个是否相等的值,然后把这个引用指向它,比如:在栈中有“asdfg”这个一个字符串,然后我们String str1 = "asdfg" ;这样的话,str1并没有在堆中生成新的字符串,而是将引用指向了栈中的“asdfg”。


2.关于“synchronized”的使用 ,线程同步问题,并发问题,线程安全。

 线程安全:指的是在多线程并发执行的程序中,怎么保证各自的线程是安全的,比如说:多个请求线程要请求某个公共资源(可以使一个对象,一个程序,一个方法,一段代码段),怎么来保证各自的请求线程中没有冲突,对请求服务的某些临界资源没有冲突。通过某种形式的互斥而实现对并发访问的保护,则代码是线程安全的。
http://en.wikipedia.org/wiki/Thread-safe  
http://pialion.blogchina.com/2531546.html开发线程安全的Spring Web应用
而synchronized关键字往往是Java应用中实现线程安全最重要的因素。

对于synchronized,它的使用可以对代码,也可以针对某个方法。
(1).对于方法,它只对某个对象来说是线程安全的,就是说
   Object o = new  **Object();对于所有操作o对象的线程是安全,并不能保证  o2,o3等等对象也是线程安全的
(2).对于代码来说,在synchronized内的代码,对于所有的线程都是安全的。
   比如:
public class  SynClass[


static Object o = new **Objcet();

.

synchronized(o)// 对象o实现并发锁,进行同步

.

}
}
在sychronized内的代码,对有SynClass 的所有对象都是线程同步的,换句话说就是,此处代码对所有的线程来说,在某一时刻只有一个线程拥有这个对象锁o,只有等这个线程执行完了以后,才释放对象锁o,这样其他的线程才能去争取这个锁O来获得代码的执行权。








posted @ 2006-10-11 10:06 圆月弯刀 阅读(1269) | 评论 (1)编辑 收藏

<2006年10月>
24252627282930
1234567
891011121314
15161718192021
22232425262728
2930311234

导航

统计

常用链接

留言簿(1)

随笔档案

最新随笔

搜索

积分与排名

最新评论

阅读排行榜

评论排行榜