parent
cceccc6276
commit
dd94810416
8 changed files with 186 additions and 9 deletions
@ -0,0 +1,118 @@ |
||||
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 extends Thread { |
||||
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) { |
||||
logger.error(e.getMessage(), e); |
||||
} |
||||
|
||||
try { |
||||
TimeUnit.DAYS.sleep(1); |
||||
} catch (InterruptedException e) { |
||||
logger.error(e.getMessage(), e); |
||||
} |
||||
} |
||||
logger.info(">>>>>>>>>>> xxl-job, executor JobLogFileCleanThread thread destory."); |
||||
|
||||
} |
||||
}); |
||||
localThread.setDaemon(true); |
||||
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); |
||||
} |
||||
} |
||||
|
||||
} |
@ -0,0 +1,27 @@ |
||||
package com.xxl.job.core.util; |
||||
|
||||
import java.io.File; |
||||
|
||||
/** |
||||
* file tool |
||||
* |
||||
* @author xuxueli 2017-12-29 17:56:48 |
||||
*/ |
||||
public class FileUtil { |
||||
|
||||
public static boolean deleteRecursively(File root) { |
||||
if (root != null && root.exists()) { |
||||
if (root.isDirectory()) { |
||||
File[] children = root.listFiles(); |
||||
if (children != null) { |
||||
for (File child : children) { |
||||
deleteRecursively(child); |
||||
} |
||||
} |
||||
} |
||||
return root.delete(); |
||||
} |
||||
return false; |
||||
} |
||||
|
||||
} |
Loading…
Reference in new issue