SpringBoot项目销毁DisposableBean接口和 @PreDestroy退出方法
- 这里用作定时框架偏移量处理 , 由于持久话已经被处理,但是偏移量还在,导致下次启动的时候,还会读取偏移量,持久化中不存在的任务还会被加载到定时队列中(意思就是这个定时任务,明明已经深删除了,但是项目中还有)
- 调用销毁方法,清除偏移量(程序即将关闭之前做的最后一件事)
① 接口实现
- 实现 DisposableBean, ExitCodeGenerator 接口
package com.base;
import org.springframework.beans.factory.DisposableBean;
import org.springframework.boot.ExitCodeGenerator;
import org.springframework.stereotype.Component;
/**
* 销毁 by CHENYB date 2019/8/13.
*/
@RestController//被spring管理的标签都可以 如:@Component @Controller
public class BaseController implements DisposableBean, ExitCodeGenerator {
@Override
public void destroy() throws Exception {
//System.out.println("<<<<<<<<<<<要销毁的事 begin>>>>>>>>>>>>>>>");
try {
this.jobService.destory();
logger.info("DESTORY JOB SUCCESS");
} catch (Exception e) {
logger.info("DESTORY JOB EXCEPTION : " + e.getMessage());
e.printStackTrace();
}
//System.out.println("<<<<<<<<<<<要销毁的事 end>>>>>>>>>>>>>>>");
}
@Override
public int getExitCode() {
return 5;
}
}
② 注解方法实现
- 使用 @PreDestroy 注解实现
@PreDestroy
public void destory() {
//System.out.println("<<<<<<<<<<<要销毁的事 begin>>>>>>>>>>>>>>>");
try {
this.jobService.destory();
logger.info("DESTORY JOB SUCCESS");
} catch (Exception e) {
logger.info("DESTORY JOB EXCEPTION : " + e.getMessage());
e.printStackTrace();
}
//System.out.println("<<<<<<<<<<<要销毁的事 end>>>>>>>>>>>>>>>");
}
- service 方法调用
@Override
public void destory() {
this.jobMapper.qrtz_blob_triggersDestory();
this.jobMapper.qrtz_calendarsDestory();
this.jobMapper.qrtz_cron_triggersDestory();
this.jobMapper.qrtz_fired_triggersDestory();
this.jobMapper.qrtz_locksDestory();
this.jobMapper.qrtz_paused_trigger_grpsDestory();
this.jobMapper.qrtz_scheduler_stateDestory();
this.jobMapper.qrtz_simple_triggersDestory();
this.jobMapper.qrtz_simprop_triggersDestory();
this.jobMapper.qrtz_triggersDestory();
this.jobMapper.qrtz_job_detailsDestory();
}
chenyb 随笔记录, 方便自己学习
2019-08-13
- 效果实现