package com.xxl.job.core.thread;
|
|
import com.xxl.job.core.log.XxlJobFileAppender;
|
import com.xxl.job.core.util.FileUtil;
|
import org.slf4j.Logger;
|
import org.slf4j.LoggerFactory;
|
|
import java.io.File;
|
import java.text.ParseException;
|
import java.text.SimpleDateFormat;
|
import java.util.Calendar;
|
import java.util.Date;
|
import java.util.concurrent.TimeUnit;
|
|
/**
|
* job file clean thread
|
*
|
* @author xuxueli 2017-12-29 16:23:43
|
*/
|
public class JobLogFileCleanThread {
|
private static Logger logger = LoggerFactory.getLogger(JobLogFileCleanThread.class);
|
|
private static JobLogFileCleanThread instance = new JobLogFileCleanThread();
|
public static JobLogFileCleanThread getInstance(){
|
return instance;
|
}
|
|
private Thread localThread;
|
private volatile boolean toStop = false;
|
public void start(final long logRetentionDays){
|
|
// limit min value
|
if (logRetentionDays < 3 ) {
|
return;
|
}
|
|
localThread = new Thread(new Runnable() {
|
@Override
|
public void run() {
|
while (!toStop) {
|
try {
|
// clean log dir, over logRetentionDays
|
File[] childDirs = new File(XxlJobFileAppender.getLogPath()).listFiles();
|
if (childDirs!=null && childDirs.length>0) {
|
|
// today
|
Calendar todayCal = Calendar.getInstance();
|
todayCal.set(Calendar.HOUR_OF_DAY,0);
|
todayCal.set(Calendar.MINUTE,0);
|
todayCal.set(Calendar.SECOND,0);
|
todayCal.set(Calendar.MILLISECOND,0);
|
|
Date todayDate = todayCal.getTime();
|
|
for (File childFile: childDirs) {
|
|
// valid
|
if (!childFile.isDirectory()) {
|
continue;
|
}
|
if (childFile.getName().indexOf("-") == -1) {
|
continue;
|
}
|
|
// file create date
|
Date logFileCreateDate = null;
|
try {
|
SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");
|
logFileCreateDate = simpleDateFormat.parse(childFile.getName());
|
} catch (ParseException e) {
|
logger.error(e.getMessage(), e);
|
}
|
if (logFileCreateDate == null) {
|
continue;
|
}
|
|
if ((todayDate.getTime()-logFileCreateDate.getTime()) >= logRetentionDays * (24 * 60 * 60 * 1000) ) {
|
FileUtil.deleteRecursively(childFile);
|
}
|
|
}
|
}
|
|
} catch (Exception e) {
|
if (!toStop) {
|
logger.error(e.getMessage(), e);
|
}
|
|
}
|
|
try {
|
TimeUnit.DAYS.sleep(1);
|
} catch (InterruptedException e) {
|
if (!toStop) {
|
logger.error(e.getMessage(), e);
|
}
|
}
|
}
|
logger.info(">>>>>>>>>>> xxl-job, executor JobLogFileCleanThread thread destroy.");
|
|
}
|
});
|
localThread.setDaemon(true);
|
localThread.setName("xxl-job, executor JobLogFileCleanThread");
|
localThread.start();
|
}
|
|
public void toStop() {
|
toStop = true;
|
|
if (localThread == null) {
|
return;
|
}
|
|
// interrupt and wait
|
localThread.interrupt();
|
try {
|
localThread.join();
|
} catch (InterruptedException e) {
|
logger.error(e.getMessage(), e);
|
}
|
}
|
|
}
|