|
|
@ -3,16 +3,21 @@ package com.xxl.job.core.thread;
|
|
|
|
import com.xxl.job.core.biz.AdminBiz;
|
|
|
|
import com.xxl.job.core.biz.AdminBiz;
|
|
|
|
import com.xxl.job.core.biz.model.HandleCallbackParam;
|
|
|
|
import com.xxl.job.core.biz.model.HandleCallbackParam;
|
|
|
|
import com.xxl.job.core.biz.model.ReturnT;
|
|
|
|
import com.xxl.job.core.biz.model.ReturnT;
|
|
|
|
|
|
|
|
import com.xxl.job.core.enums.RegistryConfig;
|
|
|
|
import com.xxl.job.core.executor.XxlJobExecutor;
|
|
|
|
import com.xxl.job.core.executor.XxlJobExecutor;
|
|
|
|
import com.xxl.job.core.log.XxlJobFileAppender;
|
|
|
|
import com.xxl.job.core.log.XxlJobFileAppender;
|
|
|
|
import com.xxl.job.core.log.XxlJobLogger;
|
|
|
|
import com.xxl.job.core.log.XxlJobLogger;
|
|
|
|
|
|
|
|
import com.xxl.job.core.util.FileUtil;
|
|
|
|
|
|
|
|
import com.xxl.job.core.util.JacksonUtil;
|
|
|
|
import org.slf4j.Logger;
|
|
|
|
import org.slf4j.Logger;
|
|
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import java.io.File;
|
|
|
|
import java.util.ArrayList;
|
|
|
|
import java.util.ArrayList;
|
|
|
|
import java.util.Date;
|
|
|
|
import java.util.Date;
|
|
|
|
import java.util.List;
|
|
|
|
import java.util.List;
|
|
|
|
import java.util.concurrent.LinkedBlockingQueue;
|
|
|
|
import java.util.concurrent.LinkedBlockingQueue;
|
|
|
|
|
|
|
|
import java.util.concurrent.TimeUnit;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* Created by xuxueli on 16/7/22.
|
|
|
|
* Created by xuxueli on 16/7/22.
|
|
|
@ -38,6 +43,7 @@ public class TriggerCallbackThread {
|
|
|
|
* callback thread
|
|
|
|
* callback thread
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
private Thread triggerCallbackThread;
|
|
|
|
private Thread triggerCallbackThread;
|
|
|
|
|
|
|
|
private Thread triggerRetryCallbackThread;
|
|
|
|
private volatile boolean toStop = false;
|
|
|
|
private volatile boolean toStop = false;
|
|
|
|
public void start() {
|
|
|
|
public void start() {
|
|
|
|
|
|
|
|
|
|
|
@ -47,6 +53,7 @@ public class TriggerCallbackThread {
|
|
|
|
return;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// callback
|
|
|
|
triggerCallbackThread = new Thread(new Runnable() {
|
|
|
|
triggerCallbackThread = new Thread(new Runnable() {
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
@ -89,16 +96,48 @@ public class TriggerCallbackThread {
|
|
|
|
});
|
|
|
|
});
|
|
|
|
triggerCallbackThread.setDaemon(true);
|
|
|
|
triggerCallbackThread.setDaemon(true);
|
|
|
|
triggerCallbackThread.start();
|
|
|
|
triggerCallbackThread.start();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// retry
|
|
|
|
|
|
|
|
triggerRetryCallbackThread = new Thread(new Runnable() {
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
|
|
|
public void run() {
|
|
|
|
|
|
|
|
while(!toStop){
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
|
|
|
retryFailCallbackFile();
|
|
|
|
|
|
|
|
} catch (Exception e) {
|
|
|
|
|
|
|
|
logger.error(e.getMessage(), e);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
|
|
|
TimeUnit.SECONDS.sleep(RegistryConfig.BEAT_TIMEOUT);
|
|
|
|
|
|
|
|
} catch (InterruptedException e) {
|
|
|
|
|
|
|
|
logger.error(e.getMessage(), e);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
logger.info(">>>>>>>>>>> xxl-job, executor retry callback thread destory.");
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
triggerRetryCallbackThread.setDaemon(true);
|
|
|
|
|
|
|
|
triggerRetryCallbackThread.start();
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
public void toStop(){
|
|
|
|
public void toStop(){
|
|
|
|
toStop = true;
|
|
|
|
toStop = true;
|
|
|
|
// interrupt and wait
|
|
|
|
// stop callback, interrupt and wait
|
|
|
|
triggerCallbackThread.interrupt();
|
|
|
|
triggerCallbackThread.interrupt();
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
triggerCallbackThread.join();
|
|
|
|
triggerCallbackThread.join();
|
|
|
|
} catch (InterruptedException e) {
|
|
|
|
} catch (InterruptedException e) {
|
|
|
|
logger.error(e.getMessage(), e);
|
|
|
|
logger.error(e.getMessage(), e);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// stop retry, interrupt and wait
|
|
|
|
|
|
|
|
triggerRetryCallbackThread.interrupt();
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
|
|
|
triggerRetryCallbackThread.join();
|
|
|
|
|
|
|
|
} catch (InterruptedException e) {
|
|
|
|
|
|
|
|
logger.error(e.getMessage(), e);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
@ -106,21 +145,25 @@ public class TriggerCallbackThread {
|
|
|
|
* @param callbackParamList
|
|
|
|
* @param callbackParamList
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
private void doCallback(List<HandleCallbackParam> callbackParamList){
|
|
|
|
private void doCallback(List<HandleCallbackParam> callbackParamList){
|
|
|
|
|
|
|
|
boolean callbackRet = false;
|
|
|
|
// callback, will retry if error
|
|
|
|
// callback, will retry if error
|
|
|
|
for (AdminBiz adminBiz: XxlJobExecutor.getAdminBizList()) {
|
|
|
|
for (AdminBiz adminBiz: XxlJobExecutor.getAdminBizList()) {
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
ReturnT<String> callbackResult = adminBiz.callback(callbackParamList);
|
|
|
|
ReturnT<String> callbackResult = adminBiz.callback(callbackParamList);
|
|
|
|
if (callbackResult!=null && ReturnT.SUCCESS_CODE == callbackResult.getCode()) {
|
|
|
|
if (callbackResult!=null && ReturnT.SUCCESS_CODE == callbackResult.getCode()) {
|
|
|
|
callbackLog(callbackParamList, "<br>----------- xxl-job callback success");
|
|
|
|
callbackLog(callbackParamList, "<br>----------- xxl-job callback success");
|
|
|
|
|
|
|
|
callbackRet = true;
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
callbackLog(callbackParamList, "<br>----------- xxl-job callback fail, callbackResult:" + callbackResult);
|
|
|
|
callbackLog(callbackParamList, "<br>----------- xxl-job callback fail, callbackResult:" + callbackResult);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} catch (Exception e) {
|
|
|
|
} catch (Exception e) {
|
|
|
|
callbackLog(callbackParamList, "<br>----------- xxl-job callback error, errorMsg:" + e.getMessage());
|
|
|
|
callbackLog(callbackParamList, "<br>----------- xxl-job callback error, errorMsg:" + e.getMessage());
|
|
|
|
//getInstance().callBackQueue.addAll(callbackParamList);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!callbackRet) {
|
|
|
|
|
|
|
|
appendFailCallbackFile(callbackParamList);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
@ -134,4 +177,49 @@ public class TriggerCallbackThread {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// ---------------------- fial-callback file TODO ----------------------
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private static String failCallbackFileName = XxlJobFileAppender.getLogPath().concat(File.separator).concat("xxl-job-callback").concat(".log");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private void appendFailCallbackFile(List<HandleCallbackParam> callbackParamList){
|
|
|
|
|
|
|
|
// append file
|
|
|
|
|
|
|
|
String content = JacksonUtil.writeValueAsString(callbackParamList);
|
|
|
|
|
|
|
|
FileUtil.appendFileLine(failCallbackFileName, content);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private void retryFailCallbackFile(){
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// load and clear file
|
|
|
|
|
|
|
|
List<String> fileLines = FileUtil.loadFileLines(failCallbackFileName);
|
|
|
|
|
|
|
|
FileUtil.deleteFile(failCallbackFileName);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// parse
|
|
|
|
|
|
|
|
List<HandleCallbackParam> failCallbackParamList = new ArrayList<>();
|
|
|
|
|
|
|
|
if (fileLines!=null && fileLines.size()>0) {
|
|
|
|
|
|
|
|
for (String line: fileLines) {
|
|
|
|
|
|
|
|
List<HandleCallbackParam> failCallbackParamListTmp = JacksonUtil.readValue(line, List.class, HandleCallbackParam.class);
|
|
|
|
|
|
|
|
if (failCallbackParamListTmp!=null && failCallbackParamListTmp.size()>0) {
|
|
|
|
|
|
|
|
failCallbackParamList.addAll(failCallbackParamListTmp);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// retry callback, 100 lines per page
|
|
|
|
|
|
|
|
if (failCallbackParamList!=null && failCallbackParamList.size()>0) {
|
|
|
|
|
|
|
|
int pagesize = 100;
|
|
|
|
|
|
|
|
List<HandleCallbackParam> pageData = new ArrayList<>();
|
|
|
|
|
|
|
|
for (int i = 0; i < failCallbackParamList.size(); i++) {
|
|
|
|
|
|
|
|
pageData.add(failCallbackParamList.get(i));
|
|
|
|
|
|
|
|
if (i>0 && i%pagesize == 0) {
|
|
|
|
|
|
|
|
doCallback(pageData);
|
|
|
|
|
|
|
|
pageData.clear();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if (pageData.size() > 0) {
|
|
|
|
|
|
|
|
doCallback(pageData);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|