spring-Task Scheduler:
There is a task in spring which is a set-time automatic Task Scheduler task that is handy when it is used, but he can do as much as quartz! You can use annotations and configuration in two ways, configured in the following ways:
1: Introduce spring to the beginning of appcation.xml
1<beans xmlns= "Http://www.springframework.org/schema/beans"2Xmlns:xsi= "Http://www.w3.org/2001/XMLSchema-instance"3xmlns:aop= "HTTP://WWW.SPRINGFRAMEWORK.ORG/SCHEMA/AOP"4xmlns:context= "Http://www.springframework.org/schema/context"5xmlns:task= "Http://www.springframework.org/schema/task"6Xsi:schemalocation= "7http//Www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans-4.0.xsd 8http//WWW.SPRINGFRAMEWORK.ORG/SCHEMA/AOPhttp://www.springframework.org/schema/aop/spring-aop-4.0.xsd 9http//Www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context-4.0.xsd Tenhttp//Www.springframework.org/schema/taskhttp://www.springframework.org/schema/task/spring-task-4.0.xsd" One default-lazy-init= "true" >
2: registering the Bean
class class= "Com.yhb.jsxn.task.JPushTaskImpl" ></bean>
3: Turn on task scheduling
1<task:scheduled-tasks>2<!--redis Tasks--3<task:scheduled ref= "Taskjob" method= "Redis" cron= "0 0 2 * *?" />4<!--share Gold daily splitting <task:scheduled ref= "Taskjob" method= "Sharingmoneydaygetmoney"5cron= "0 30 0 * *?" />-Interest rate coupon daily splitting <task:scheduled ref= "Taskjob" method= "Raisetask"6cron= "0 40 0 * *?" /> Experience Gold daily splitting <task:scheduled ref= "Taskjob" method= "Experiencetask"7cron= "0 50 0 * *?" />--8<!--boost my earnings every day--9<task:scheduled ref= "Jpushtask" method= "pushinvesttotalrevenue" cron= "0 00 3 * *?" />Ten<!--bonus three days before expiry date---- One<task:scheduled ref= "Jpushtask" method= "pushredbeforeoverdue" cron= "0 20 2 * *?" /> A<!--three days before the coupon expires-- -<task:scheduled ref= "Jpushtask" method= "pushraisebeforeoverdue" cron= "0 30 2 * *?" /> -< three days before the expiration date of the experience payment----!-- the<task:scheduled ref= "Jpushtask" method= "pushexlistbeforeoverdue" cron= "0 40 2 * *?" /> -<!--three days before the date of the purchased product has been pushed-- -<task:scheduled ref= "Jpushtask" method= "pushproductbeforeoverdue" cron= "0 50 2 * *?" /> -<!--three days before the expiry of the purchased insurance. +<task:scheduled ref= "Jpushtask" method= "pushproductbeforeoverdue" cron= "0 55 2 * *?" /> -<!--daily 7:30 A.M. reminder Sign in/share- +<task:scheduled ref= "Jpushtask" method= "Welfareeveryday" cron= "0 30 7 * *?" /> A at</task:scheduled-tasks>
1 <task:scheduled-tasks> 2 <task:scheduled ref= "Voicefileclearjob" method= "execute" Initial-delay= "fixed-delay=" 3600000 "/> 3 <task:scheduled ref=" Versionlistenjob " Method= "Execute" initial-delay= "fixed-delay="/> 4 <task:scheduled ref= "Statjob "Method=" Statlgj "cron=" 0 59 23 * *? " /> 5 <task:scheduled ref= "Statjob" method= "Statbadnameandqq" cron= "23 28 20 * *?" /> 6 </task:scheduled-tasks>
which
Ref is a work class
Method is the way to execute in a work class
Initial-delay is the delay before the task is called for the first time, unit milliseconds
Fixed-delay is the delay that is called again after the last call is completed
Fixed-rate is the delay that is called again after the start of the previous call (without waiting for the last call to complete)
Cron is an expression that indicates when a task is scheduled.
Cron expression:
A cron expression has at least 6 (or possibly 7) time elements that have a space separation.
In order of
Seconds (0~59)
Minutes (0~59)
Hours (0~23)
Days (months) (0~31, but you need to consider the number of days of your month)
Month (0~11)
Days (weeks) (1~7 1=sun or Sun,mon,tue,wed,thu,fri,sat)
Year (1970-2099)
Each of these elements can be a value (such as 6), a continuous interval (9-12), a time interval (8-18/4) (/= every 4 hours), a list (1,3,5), and a wildcard character. Because the "date in the month" and "date in the week" are mutually exclusive, one of the two elements must be set.
0 0 10,14,16 * *? 10 o'clock in the morning, 2 o'clock in the afternoon, 4 O ' Day
0 0/30 9-17 * *? Every half hour for nine to five working hours
0 0 12? * WED means every Wednesday noon 12 o'clock
"0 0 12 * *?" trigger 12 o'clock noon every day.
"0 15 10?" * * "trigger 10:15 every day"
"0 15 10 * *?" Daily 10:15 Trigger
"0 15 10 * *?" * "10:15 per day" trigger
"0 15 10 * *?" 2005 "2005-year daily 10:15 Trigger
"0 * 14 * *?" triggers every 1 minutes from 2 o'clock in the afternoon to 2:59 daily
"0 0/5 14 * *?" triggers every 5 minutes from 2 o'clock in the afternoon to 2:55 daily
"0 0/5 14,18 * *?" triggers every 5 minutes from 2 o'clock in the afternoon to 2:55 daily and from 6 o'clock in the afternoon to 6:55
"0 0-5 14 * *?" triggers every 1 minutes from 2 o'clock in the afternoon to 2:05 daily
"0 10,44 14?" 3 WED "2:10 and 2:44 triggers in Wednesday of every March
"0 15 10?" * Mon-fri "Monday to Friday 10:15 trigger
"0 15 10 15 *?" 15th 10:15 per month
"0 L *?" 10:15 on the last day of the month
"0 15 10?" * 6L "Last month of Friday 10:15 Trigger
"0 15 10?" * 6L 2002-2005 "2002 to 2005 the last of the monthly Friday 10:15 trigger
"0 15 10?" * 6#3 "Monthly third Friday 10:15 trigger
Some sub-expressions can contain ranges or lists
For example: subexpression (Day (week)) can be "Mon-fri", "Mon,wed,fri", "Mon-wed,sat"
The "*" character represents all possible values
Therefore, "*" in the sub-expression (month) represents the meaning of each month, "*" in the subexpression (Day (week)) represents every day of the week
The "/" character is used to specify the increment of the numeric value
For example: "0/15" in sub-expressions (minutes) means starting from the No. 0 minute, every 15 minutes
"3/20" in the sub-expression (minutes) means that every 20 minutes (it is the same as "3,23,43") starting from the 3rd minute
“? "Character is used only for days (months) and days (weeks) of two sub-expressions, indicating that no value is specified
When one of the 2 sub-expressions is assigned a value, in order to avoid a conflict, you need to set the value of another subexpression to "? ”
The "L" character is used only for days (months) and days (weeks) of two sub-expressions, which is the abbreviation for the word "last"
But it has a different meaning in two sub-expressions.
In the day (month) subexpression, "L" represents the last day of the one-month
In the day (week) Self-expression, "L" represents the last day of one weeks, the SAT
If there is something specific before "L", it has other meanings.
For example: "6L" means the 6th day of the month, and "Fril" means the last Friday of the month.
Note: When using the "L" parameter, do not specify a list or range, as this can cause problems
Field |
| allowed
special characters for |
allowable values |
|
Seconds |
|
0-59 |
|
, - * / |
Score of |
|
0-59 |
|
, - * / |
Hours |
|
0-23 |
|
, - * / |
Date |
|
1-31 |
|
, - * ? /L W C |
Month |
|
1-12 or Jan-dec |
|
, - * / |
Week |
|
1-7 or Sun-sat |
|
, - * ? /L C # |
Year (optional) |
|
Leave Blank, 1970-2099 |
|
, - * / |
"Spring-Task Scheduler"