package cn.sup.cd.listener; import cn.sup.cd.common.util.PropertyUtils; import cn.sup.cd.common.util.Struts2Utils; import cn.sup.cd.domain.TemperMonitor; import cn.sup.cd.service.ITemperMonitorService; public class TemperatureMonitorTaskJob { private TemperMonitor temperMonitor = null; /** * * 描述 */ public void temperatureMonitorTimer(){ // 监控周期时间 String monitorCycle = PropertyUtils.getConfigParam("monitor.cycle")+"月份"; // 室内温度 起: String indoorTemperatureStart = PropertyUtils.getConfigParam("indoor.temperature.start"); // 室内温度 止: String indoorTemperatureEnd = PropertyUtils.getConfigParam("indoor.temperature.end"); // 室外温度 起: String outdoorTemperatureStart = PropertyUtils.getConfigParam("outdoor.temperature.start"); // 室外温度 止: String outdoorTemperatureEnd = PropertyUtils.getConfigParam("outdoor.temperature.end"); // 随机产生的室内温度值 Integer indoorTemperatureResult = getIndoorTemperatureResult( indoorTemperatureStart, indoorTemperatureEnd); // 随机产生的室外温度值 Integer outdoorTemperatureResult = getOutdoorTemperatureResult( outdoorTemperatureStart, outdoorTemperatureEnd); //添加监控数据 insertTemperMonitorResult(monitorCycle, indoorTemperatureResult, outdoorTemperatureResult); } /** * 定时添加监控室内室外温度值 * @param monitorCycle * @param indoorTemperatureResult * @param outdoorTemperatureResult */ @SuppressWarnings("unused") private void insertTemperMonitorResult(String monitorCycle, Integer indoorTemperatureResult, Integer outdoorTemperatureResult) { temperMonitor = new TemperMonitor(); if (null != monitorCycle) { temperMonitor.setMonitor_cycle(monitorCycle); } if (null != indoorTemperatureResult) { temperMonitor.setIndoor_temperature(indoorTemperatureResult+""); } if (null != outdoorTemperatureResult) { temperMonitor.setOutdoor_temperature(outdoorTemperatureResult+""); } temperMonitor.setMonitor_time(Struts2Utils.getCurrenttime_hms()); ITemperMonitorService temperMonitorService = (ITemperMonitorService)Struts2Utils.getBean("temperMonitorServiceImpl"); temperMonitorService.insert(temperMonitor); } /** * 产生随机的室内温度值 * * @param indoorTemperatureStart * 室内温度值 起: * @param indoorTemperatureEnd * 室内温度值 止: * @return */ @SuppressWarnings("unused") private Integer getIndoorTemperatureResult(String indoorTemperatureStart, String indoorTemperatureEnd) { if (null != indoorTemperatureEnd && null != indoorTemperatureStart) { return Integer.valueOf(indoorTemperatureStart) + (int) (Math.random() * ((Integer .valueOf(indoorTemperatureEnd) - Integer .valueOf(indoorTemperatureStart)) + 1)); } return null; } /** * 产生随机的室外温度值 * * @param outdoorTemperatureStart * 室内温度值 起: * @param outdoorTemperatureEnd * 室内温度值 止 : * @return */ @SuppressWarnings("unused") private Integer getOutdoorTemperatureResult(String outdoorTemperatureStart, String outdoorTemperatureEnd) { // 产生的随机室外温度值 if (null != outdoorTemperatureEnd && null != outdoorTemperatureStart) { return Integer.valueOf(outdoorTemperatureStart) + (int) (Math.random() * ((Integer .valueOf(outdoorTemperatureEnd) - Integer .valueOf(outdoorTemperatureStart)) + 1)); } return null; } }
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd"> <bean id="temperMonitorTimerJob" class="cn.sup.cd.listener.TemperatureMonitorTaskJob"></bean> <!-- 政策调度--> <bean id="temperMonitorTask" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean"> <!-- 调用的类 --> <property name="targetObject"> <ref bean="temperMonitorTimerJob"/> </property> <!-- 调用类中的方法 --> <property name="targetMethod"> <value>temperatureMonitorTimer</value> </property> </bean> <!-- BOOK定义触发时间 几秒后执行monitor.start.time 每隔monitor.interval.time执行--> <bean id="getPolicyTime" class="org.springframework.scheduling.quartz.CronTriggerBean"> <property name="jobDetail"> <ref bean="temperMonitorTask"/> </property> <!-- cron表达式 --> <property name="cronExpression"> <value> ${monitor.start.time}/${monitor.interval.time} * * * * ? </value> </property> </bean> <!-- 总管理类 如果将lazy-init='false'那么容器启动就会执行调度程序 --> <bean id="startQuertz" lazy-init="false" autowire="no" class="org.springframework.scheduling.quartz.SchedulerFactoryBean"> <property name="triggers"> <list> <ref bean="getPolicyTime"/> </list> </property> </bean> </beans>
quartz 时间配置规则
格式: [秒] [分] [小时] [日] [月] [周] [年]
序号 | 说明 | 是否必填 | 允许填写的值 | 允许的通配符 |
1 | 秒 | 是 | 0-59 | , - * / |
2 | 分 | 是 | 0-59 | , - * / |
3 | 小时 | 是 | 0-23 | , - * / |
4 | 日 | 是 | 1-31 | , - * ? / L W |
5 | 月 | 是 | 1-12 or JAN-DEC | , - * / |
6 | 周 | 是 | 1-7 or SUN-SAT | , - * ? / L # |
7 | 年 | 否 | empty 或 1970-2099 | , - * / |
通配符说明:
* 表示所有值. 例如:在分的字段上设置 "*",表示每一分钟都会触发。
? 表示不指定值。使用的场景为不需要关心当前设置这个字段的值。例如:要在每月的10号触发一个操作,但不关心是周几,所以需要周位置的那个字段设置 为"?" 具体设置为 0 0 0 10 * ?
- 表示区间。例如 在小时上设置 "10-12",表示 10,11,12点都会触发。
, 表示指定多个值,例如在周字段上设置 "MON,WED,FRI" 表示周一,周三和周五触发
/ 用于递增触发。如在秒上面设置"5/15" 表示从5秒开始,每增15秒触发(5,20,35,50)。 在月字段上设置'1/3'所示每月1号开始,每隔三天触发一次。
L 表示最后的意思。在日字段设置上,表示当月的最后一天(依据当前月份,如果是二月还会依据是否是润年[leap]), 在周字段上表示星期六,相当于"7"或"SAT"。如果在"L"前加上数字,则表示该数据的最后一个。例如在周字段上设置"6L"这样的格式,则表示“本 月最后一个星期五"
W 表示离指定日期的最近那个工作日(周一至周五). 例如在日字段上设置"15W",表示离每月15号最近的那个工作日触发。如果15号正好是周六,则找最近的周五(14号)触发, 如果15号是周未,则找最近的下周一(16号)触发.如果15号正好在工作日(周一至周五),则就在该天触发。如果指定格式为 "1W",它则表示每月1号往后最近的工作日触发。如果1号正是周六,则将在3号下周一触发。(注,"W"前只能设置具体的数字,不允许区间"-").
小提示 |
'L'和 'W'可以一组合使用。如果在日字段上设置"LW",则表示在本月的最后一个工作日触发(一般指发工资 ) |
# 序号(表示每月的第几个周几),例如在周字段上设置"6#3"表示在每月的第三个周六.注意如果指定"#5",正好第五周没有周六,则不会触发该配置(用 在母亲节和父亲节再合适不过了)
小提示 |
周字段的设置,若使用英文字母是不区分大小写的 MON 与mon相同 . |
常用示例:
0 0 12 * * ? | 每天12点触发 |
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点到2点59分每分触发 |
0 0/5 14 * * ? | 每天下午的 2点到2点59分(整点开始,每隔5分触发) |
0 0/5 14,18 * * ? | 每天下午的 2点到2点59分(整点开始,每隔5分触发) 每天下午的 18点到18点59分(整点开始,每隔5分触发) |
0 0-5 14 * * ? | 每天下午的 2点到2点05分每分触发 |
0 10,44 14 ? 3 WED | 3月分每周三下午的 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 ? * 6L 2002-2005 | 从2002年到2005年每月最后一周的星期五的10点15分触发 |
0 15 10 ? * 6#3 | 每月的第三周的星期五开始触发 |
0 0 12 1/5 * ? | 每月的第一个中午开始每隔5天触发一次 |
0 11 11 11 11 ? | 每年的11月11号 11点11分触发(光棍节) |
相关推荐
关于spring中quartz的配置
Spring中的Quartz配置-Spring-定时器-java定时器.doc
spring-quartz的标准配置文件
Spring Quartz如何动态配置时间
spring 集成quartz定时任务 用数据库实现quartz的集群
针对于spring集成quartz配置进行详细说明,并提供部分简单示例说明配置。
Spring中Quartz详细配置实例+所用包(spring.jar quartz-all-1.6.0.jar log4j-1.2.14.jar commons-collections.jar jta.jar commons-logging.jar)
java + quartz实现定时任务,实现集群配置,在集群环境下多节点运行定时Quartz定任务,就会存在重复处理任务的现象,为解决这一问题,下面我将介绍使用 Quartz 的 TASK ( 12 张表)实例化到数据库,基于数据库自动...
spring注解Quartz定时执行功能
Quartz学习文档 Spring + Quartz配置详细实例 jar包 Quartz时间格式设置
Spring中Quartz任务调度器cronexpression配置说明
Spring中Quartz的配置[总结].pdf
spring 在配置quartz定时任务时所需要的jar包,里面含有两个包quartz-all-1.8.3和commons-logging-1.0.4
spring3 配置quartz定时任务的使用。一个小例子。可直接运行Test.java。就可以启动定时任务。每10秒钟执行一次,可以根据自己配置。
spring quartz 非配置动态定时
NULL 博文链接:https://javaeedevelop.iteye.com/blog/1540461
Quartz2.2.1基于Spring注解方式配置QuartzL,具体过程的效果看博文 http://blog.csdn.net/evankaka/article/details/45400781
NULL 博文链接:https://duanfei.iteye.com/blog/1732839
定时任务demo,Java语言,spring整合quartz配置文件实现定时任务