spring
Wykonywanie i planowanie zadań
Szukaj…
Włącz harmonogram
Wiosna zapewnia przydatne wsparcie przy planowaniu zadań. Aby go włączyć, tylko opisywanie wszystkich swoich @Configuration
klas z @EnableScheduling
:
@Configuration
@EnableScheduling
public class MyConfig {
// Here it goes your configuration
}
Naprawiono opóźnienie
Jeśli chcemy, aby jakiś kod był wykonywany okresowo po zakończeniu wcześniejszego wykonania, powinniśmy zastosować stałe opóźnienie (mierzone w milisekundach):
@Component
public class MyScheduler{
@Scheduled(fixedDelay=5000)
public void doSomething() {
// this will execute periodically, after the one before finishes
}
}
Stała stawka
Jeśli chcemy, aby coś było wykonywane okresowo, ten kod będzie uruchamiany raz na określoną w milisekundach wartość:
@Component
public class MyScheduler{
@Scheduled(fixedRate=5000)
public void doSomething() {
// this will execute periodically
}
}
Wyrażenie cron
Wyrażenie Cron składa się z sześciu kolejnych pól -
second, minute, hour, day of month, month, day(s) of week
i zadeklarowano w następujący sposób
@Scheduled(cron = "* * * * * *")
Możemy również ustawić strefę czasową jako -
@Scheduled(cron="* * * * * *", zone="Europe/Istanbul")
Uwagi: -
syntax means example explanation
------------------------------------------------------------------------------------
* match any "* * * * * *" do always
*/x every x "*/5 * * * * *" do every five seconds
? no specification "0 0 0 25 12 ?" do every Christmas Day
Przykład: -
syntax means
------------------------------------------------------------------------------------
"0 0 * * * *" the top of every hour of every day.
"*/10 * * * * *" every ten seconds.
"0 0 8-10 * * *" 8, 9 and 10 o'clock of every day.
"0 0/30 8-10 * * *" 8:00, 8:30, 9:00, 9:30 and 10 o'clock every day.
"0 0 9-17 * * MON-FRI" on the hour nine-to-five weekdays
"0 0 0 25 12 ?" every Christmas Day at midnight
Metoda zadeklarowana za pomocą @Scheduled()
jest wywoływana jawnie dla każdego pasującego przypadku.
Jeśli chcemy, aby jakiś kod był wykonywany po spełnieniu wyrażenia cron, musimy to określić w adnotacji:
@Component
public class MyScheduler{
@Scheduled(cron="*/5 * * * * MON-FRI")
public void doSomething() {
// this will execute on weekdays
}
}
Jeśli chcemy wydrukować aktualny czas w naszej konsoli co 5 sekund -
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
import java.text.SimpleDateFormat;
import java.util.Date;
@Component
public class Scheduler {
private static final Logger log = LoggerFactory.getLogger(Scheduler.class);
private static final SimpleDateFormat dateFormat = new SimpleDateFormat("HH:mm:ss");
@Scheduled(cron = "*/5 * * * * *")
public void currentTime() {
log.info("Current Time = {}", dateFormat.format(new Date()));
}
}
Przykład użycia konfiguracji XML:
Przykładowa klasa:
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import java.text.SimpleDateFormat;
import java.util.Date;
@Component("schedulerBean")
public class Scheduler {
private static final Logger log = LoggerFactory.getLogger(Scheduler.class);
private static final SimpleDateFormat dateFormat = new SimpleDateFormat("HH:mm:ss");
public void currentTime() {
log.info("Current Time = {}", dateFormat.format(new Date()));
}
}
Przykład XML (task-context.xml):
<?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:task="http://www.springframework.org/schema/task"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-4.1.xsd
http://www.springframework.org/schema/task
http://www.springframework.org/schema/task/spring-task-4.1.xsd">
<task:scheduled-tasks scheduler="scheduledTasks">
<task:scheduled ref="schedulerBean" method="currentTime" cron="*/5 * * * * MON-FRI" />
</task:scheduled-tasks>
<task:scheduler id="scheduledTasks" />
</beans>