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