最近遇到问题,需要写一个程序每隔一段时间去检测数据库超时的query,然后杀掉该query的进程。用到了Java自带的定时器。
Timer用法
delay和period都是long类型的延迟时间, 单位为毫秒
timer.schedule(task, time); //在time时间执行task任务1次
timer.schedule(task, delay); //在延迟delay毫秒后执行task任务1次
timer.schedule(task, firstTime, period); //在firsttime时间执行task1次,之后定期period毫秒时间执行task, 时间如果为过去时间, 不会执行过去没有执行的任务, 但是会马上执行
timer.schedule(task, delay, period); // 在延迟delay后执行task1次,之后定期period毫秒时间执行task, 时间如果为过去时间, 不会执行过去没有执行的任务, 但是会马上执行
timer.scheduleAtFixedRate(task, firstTime, period); // 在firstTime时间执行task一次, 以后每隔period毫秒执行1次, 时间如果为过去时间, 会执行过去没有执行的任务, 但是会马上执行
timer.scheduleAtFixedRate(task, delay, period); // 在delay毫秒后执行task一次, 以后每隔period毫秒执行1次, 时间如果为过去时间, 会执行过去没有执行的任务, 但是会马上执行
简化的例子
import java.util.Timer;
/**
* Springboot启动后,延迟1分钟执行定时任务
*/
@Component
public class MyStartRun implements CommandLineRunner {
@Value("${demo.timeout}")
private Integer timeOut;
@Autowired
private MyTimerTask myTimerTask;
@Override
public void run(String... args) throws Exception {
Timer timer = new Timer();
timer.schedule(clearTimerTask,60*1000,timeOut*1000);
}
}
/**
* 定时任务,每隔timeOut秒查询超时timeOut的st_asmvt任务,杀掉该进程
*/
@Component
public class MyTimerTask extends TimerTask {
@Value("${demo.timeout}")
private Integer timeOut;
@Autowired
@Qualifier("jdbcTemplate2")
private JdbcTemplate jdbcTemplate;
@Override
public void run() {
//do something
}
}