|
|
@@ -3,8 +3,8 @@ package com.xxl.job.admin.core.jobbean;
|
|
3
|
3
|
import com.xxl.job.admin.core.callback.XxlJobLogCallbackServer;
|
|
4
|
4
|
import com.xxl.job.admin.core.model.XxlJobInfo;
|
|
5
|
5
|
import com.xxl.job.admin.core.model.XxlJobLog;
|
|
6
|
|
-import com.xxl.job.admin.core.model.XxlJobRegistry;
|
|
7
|
6
|
import com.xxl.job.admin.core.thread.JobMonitorHelper;
|
|
|
7
|
+import com.xxl.job.admin.core.thread.JobRegistryHelper;
|
|
8
|
8
|
import com.xxl.job.admin.core.util.DynamicSchedulerUtil;
|
|
9
|
9
|
import com.xxl.job.core.registry.RegistHelper;
|
|
10
|
10
|
import com.xxl.job.core.router.HandlerRouter.ActionRepository;
|
|
|
@@ -60,17 +60,12 @@ public class RemoteHttpJobBean extends QuartzJobBean {
|
|
60
|
60
|
List<String> addressList = new ArrayList<String>();
|
|
61
|
61
|
String parseAddressMsg = null;
|
|
62
|
62
|
if (StringUtils.isNotBlank(jobInfo.getExecutorAppname())) {
|
|
63
|
|
- List<XxlJobRegistry> xxlJobRegistryList = DynamicSchedulerUtil.xxlJobRegistryDao.findRegistrys(RegistHelper.RegistType.EXECUTOR.name(), jobInfo.getExecutorAppname());
|
|
64
|
|
- if (xxlJobRegistryList!=null && xxlJobRegistryList.size()>0) {
|
|
65
|
|
- for (XxlJobRegistry item: xxlJobRegistryList) {
|
|
66
|
|
- addressList.add(item.getRegistryValue());
|
|
67
|
|
- }
|
|
68
|
|
- }
|
|
69
|
|
- parseAddressMsg = MessageFormat.format("Parse Address (Appname注册方式) <br>>>>[address list] : {0}<br><hr>", addressList.toArray());
|
|
|
63
|
+ addressList = JobRegistryHelper.discover(RegistHelper.RegistType.EXECUTOR.name(), jobInfo.getExecutorAppname());
|
|
|
64
|
+ parseAddressMsg = MessageFormat.format("Parse Address (Appname注册方式) <br>>>>[address list] : {0}<br><hr>", addressList);
|
|
70
|
65
|
} else {
|
|
71
|
66
|
List<String> addressArr = Arrays.asList(jobInfo.getExecutorAddress().split(","));
|
|
72
|
67
|
addressList.addAll(addressArr);
|
|
73
|
|
- parseAddressMsg = MessageFormat.format("Parse Address (地址配置方式) <br>>>>[address list] : {0}<br><hr>", addressList.toArray());
|
|
|
68
|
+ parseAddressMsg = MessageFormat.format("Parse Address (地址配置方式) <br>>>>[address list] : {0}<br><hr>", addressList);
|
|
74
|
69
|
}
|
|
75
|
70
|
|
|
76
|
71
|
// failover trigger
|
|
|
@@ -97,7 +92,21 @@ public class RemoteHttpJobBean extends QuartzJobBean {
|
|
97
|
92
|
* @return
|
|
98
|
93
|
*/
|
|
99
|
94
|
public ResponseModel failoverTrigger(List<String> addressList, RequestModel requestModel, XxlJobLog jobLog){
|
|
100
|
|
- if (addressList.size() > 1) {
|
|
|
95
|
+ if (addressList==null || addressList.size() < 1) {
|
|
|
96
|
+ ResponseModel result = new ResponseModel();
|
|
|
97
|
+ result.setStatus(ResponseModel.FAIL);
|
|
|
98
|
+ result.setMsg( "Trigger error, <br>>>>address list is null <br><hr>" );
|
|
|
99
|
+ return result;
|
|
|
100
|
+ } else if (addressList.size() == 1) {
|
|
|
101
|
+ String address = addressList.get(0);
|
|
|
102
|
+ // store real address
|
|
|
103
|
+ jobLog.setExecutorAddress(address);
|
|
|
104
|
+
|
|
|
105
|
+ ResponseModel triggerCallback = XxlJobNetCommUtil.postHex(XxlJobNetCommUtil.addressToUrl(address), requestModel);
|
|
|
106
|
+ String failoverMessage = MessageFormat.format("Trigger running, <br>>>>[address] : {0}, <br>>>>[status] : {1}, <br>>>>[msg] : {2} <br><hr>", address, triggerCallback.getStatus(), triggerCallback.getMsg());
|
|
|
107
|
+ triggerCallback.setMsg(failoverMessage);
|
|
|
108
|
+ return triggerCallback;
|
|
|
109
|
+ } else {
|
|
101
|
110
|
|
|
102
|
111
|
// for ha
|
|
103
|
112
|
Collections.shuffle(addressList);
|
|
|
@@ -133,20 +142,6 @@ public class RemoteHttpJobBean extends QuartzJobBean {
|
|
133
|
142
|
result.setStatus(ResponseModel.FAIL);
|
|
134
|
143
|
result.setMsg(failoverMessage);
|
|
135
|
144
|
return result;
|
|
136
|
|
- } else if (addressList.size() == 1) {
|
|
137
|
|
- String address = addressList.get(0);
|
|
138
|
|
- // store real address
|
|
139
|
|
- jobLog.setExecutorAddress(address);
|
|
140
|
|
-
|
|
141
|
|
- ResponseModel triggerCallback = XxlJobNetCommUtil.postHex(XxlJobNetCommUtil.addressToUrl(address), requestModel);
|
|
142
|
|
- String failoverMessage = MessageFormat.format("Trigger running, <br>>>>[address] : {0}, <br>>>>[status] : {1}, <br>>>>[msg] : {2} <br><hr>", address, triggerCallback.getStatus(), triggerCallback.getMsg());
|
|
143
|
|
- triggerCallback.setMsg(failoverMessage);
|
|
144
|
|
- return triggerCallback;
|
|
145
|
|
- } else {
|
|
146
|
|
- ResponseModel result = new ResponseModel();
|
|
147
|
|
- result.setStatus(ResponseModel.FAIL);
|
|
148
|
|
- result.setMsg( "Trigger error, <br>>>>address list is null <br><hr>" );
|
|
149
|
|
- return result;
|
|
150
|
145
|
}
|
|
151
|
146
|
}
|
|
152
|
147
|
|