XxlJobServiceImpl.java 8.8 KB
Newer Older
1 2
package com.xxl.job.admin.service.impl;

X
xueli.xue 已提交
3
import com.xxl.job.admin.core.model.XxlJobGroup;
4
import com.xxl.job.admin.core.model.XxlJobInfo;
5
import com.xxl.job.admin.core.schedule.XxlJobDynamicScheduler;
X
xueli.xue 已提交
6
import com.xxl.job.admin.dao.IXxlJobGroupDao;
7 8 9 10
import com.xxl.job.admin.dao.IXxlJobInfoDao;
import com.xxl.job.admin.dao.IXxlJobLogDao;
import com.xxl.job.admin.dao.IXxlJobLogGlueDao;
import com.xxl.job.admin.service.IXxlJobService;
11
import com.xxl.job.core.biz.model.ReturnT;
X
fresh  
xueli.xue 已提交
12 13 14 15 16 17 18 19 20
import org.apache.commons.lang.StringUtils;
import org.apache.commons.lang.time.FastDateFormat;
import org.quartz.CronExpression;
import org.quartz.SchedulerException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Service;

import javax.annotation.Resource;
X
coding  
xueli.xue 已提交
21
import java.text.MessageFormat;
X
fresh  
xueli.xue 已提交
22 23 24 25
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
26 27

/**
X
init  
xueli.xue 已提交
28
 * core job action for xxl-job
29 30 31 32
 * @author xuxueli 2016-5-28 15:30:33
 */
@Service
public class XxlJobServiceImpl implements IXxlJobService {
X
fresh  
xueli.xue 已提交
33
	private static Logger logger = LoggerFactory.getLogger(XxlJobServiceImpl.class);
34

X
xueli.xue 已提交
35 36
	@Resource
	private IXxlJobGroupDao xxlJobGroupDao;
37 38 39 40 41 42 43 44
	@Resource
	private IXxlJobInfoDao xxlJobInfoDao;
	@Resource
	public IXxlJobLogDao xxlJobLogDao;
	@Resource
	private IXxlJobLogGlueDao xxlJobLogGlueDao;
	
	@Override
45
	public Map<String, Object> pageList(int start, int length, int jobGroup, String executorHandler, String filterTime) {
X
fresh  
xueli.xue 已提交
46

47
		// page list
X
fresh  
xueli.xue 已提交
48 49
		List<XxlJobInfo> list = xxlJobInfoDao.pageList(start, length, jobGroup, executorHandler);
		int list_count = xxlJobInfoDao.pageListCount(start, length, jobGroup, executorHandler);
50 51 52 53
		
		// fill job info
		if (list!=null && list.size()>0) {
			for (XxlJobInfo jobInfo : list) {
54
				XxlJobDynamicScheduler.fillJobInfo(jobInfo);
55 56 57 58 59 60 61 62 63 64 65 66
			}
		}
		
		// package result
		Map<String, Object> maps = new HashMap<String, Object>();
	    maps.put("recordsTotal", list_count);		// 总记录数
	    maps.put("recordsFiltered", list_count);	// 过滤后的总记录数
	    maps.put("data", list);  					// 分页列表
		return maps;
	}

	@Override
67
	public ReturnT<String> add(int jobGroup, String jobCron, String jobDesc, String author, String alarmEmail,
X
xueli.xue 已提交
68
							   String executorHandler, String executorParam,
69
							   int glueSwitch, String glueSource, String glueRemark, String childJobKey) {
70
		// valid
X
xueli.xue 已提交
71 72 73
		XxlJobGroup group = xxlJobGroupDao.load(jobGroup);
		if (group == null) {
			return new ReturnT<String>(500, "请选择“执行器”");
74 75
		}
		if (!CronExpression.isValidExpression(jobCron)) {
X
xueli.xue 已提交
76
			return new ReturnT<String>(500, "请输入格式正确的“Cron”");
77 78 79 80 81 82 83 84 85 86
		}
		if (StringUtils.isBlank(jobDesc)) {
			return new ReturnT<String>(500, "请输入“任务描述”");
		}
		if (StringUtils.isBlank(author)) {
			return new ReturnT<String>(500, "请输入“负责人”");
		}
		if (StringUtils.isBlank(alarmEmail)) {
			return new ReturnT<String>(500, "请输入“报警邮件”");
		}
X
fresh  
xueli.xue 已提交
87 88 89
		if (glueSwitch==0 && StringUtils.isBlank(executorHandler)) {
			return new ReturnT<String>(500, "请输入“JobHandler”");
		}
X
xueli.xue 已提交
90

X
coding  
xueli.xue 已提交
91 92 93 94 95 96 97 98
		// childJobKey valid
		if (StringUtils.isNotBlank(childJobKey)) {
			String[] childJobKeys = childJobKey.split(",");
			for (String childJobKeyItem: childJobKeys) {
				String[] childJobKeyArr = childJobKeyItem.split("_");
				if (childJobKeyArr.length!=2) {
					return new ReturnT<String>(500, MessageFormat.format("子任务Key({0})格式错误", childJobKeyItem));
				}
99
				XxlJobInfo childJobInfo = xxlJobInfoDao.load(Integer.valueOf(childJobKeyArr[0]), childJobKeyArr[1]);
X
coding  
xueli.xue 已提交
100 101 102 103 104 105
				if (childJobInfo==null) {
					return new ReturnT<String>(500, MessageFormat.format("子任务Key({0})无效", childJobKeyItem));
				}
			}
		}

X
xueli.xue 已提交
106
		// generate jobName
107
		String jobName = FastDateFormat.getInstance("yyyyMMddHHmmssSSSS").format(new Date());
108
		try {
109
			if (XxlJobDynamicScheduler.checkExists(jobName, String.valueOf(jobGroup))) {
110
				return new ReturnT<String>(500, "系统繁忙,请稍后重试");
111 112 113
			}
		} catch (SchedulerException e1) {
			e1.printStackTrace();
114
			return new ReturnT<String>(500, "系统繁忙,请稍后重试");
115
		}
X
xueli.xue 已提交
116

117 118
		// Backup to the database
		XxlJobInfo jobInfo = new XxlJobInfo();
119
		jobInfo.setJobGroup(jobGroup);
120 121 122 123 124
		jobInfo.setJobName(jobName);
		jobInfo.setJobCron(jobCron);
		jobInfo.setJobDesc(jobDesc);
		jobInfo.setAuthor(author);
		jobInfo.setAlarmEmail(alarmEmail);
X
fresh  
xueli.xue 已提交
125 126
		jobInfo.setExecutorHandler(executorHandler);
		jobInfo.setExecutorParam(executorParam);
127 128 129
		jobInfo.setGlueSwitch(glueSwitch);
		jobInfo.setGlueSource(glueSource);
		jobInfo.setGlueRemark(glueRemark);
130
		jobInfo.setChildJobKey(childJobKey);
X
xueli.xue 已提交
131

132 133
		try {
			// add job 2 quartz
134
			boolean result = XxlJobDynamicScheduler.addJob(String.valueOf(jobGroup), jobName, jobCron);
135
			if (result) {
X
fresh  
xueli.xue 已提交
136
				xxlJobInfoDao.save(jobInfo);
137 138 139 140 141
				return ReturnT.SUCCESS;
			} else {
				return new ReturnT<String>(500, "新增任务失败");
			}
		} catch (SchedulerException e) {
X
fresh  
xueli.xue 已提交
142
			logger.error("", e);
143 144 145 146 147
		}
		return ReturnT.FAIL;
	}

	@Override
X
xueli.xue 已提交
148
	public ReturnT<String> reschedule(int jobGroup, String jobName, String jobCron, String jobDesc, String author, String alarmEmail,
X
xueli.xue 已提交
149
			String executorHandler, String executorParam, int glueSwitch, String childJobKey) {
X
fresh  
xueli.xue 已提交
150

151
		// valid
X
xueli.xue 已提交
152 153 154
		XxlJobGroup group = xxlJobGroupDao.load(jobGroup);
		if (group == null) {
			return new ReturnT<String>(500, "请选择“执行器”");
155 156 157 158 159
		}
		if (StringUtils.isBlank(jobName)) {
			return new ReturnT<String>(500, "请输入“任务名”");
		}
		if (!CronExpression.isValidExpression(jobCron)) {
X
xueli.xue 已提交
160
			return new ReturnT<String>(500, "请输入格式正确的“Cron”");
161 162 163 164 165 166 167 168 169 170
		}
		if (StringUtils.isBlank(jobDesc)) {
			return new ReturnT<String>(500, "请输入“任务描述”");
		}
		if (StringUtils.isBlank(author)) {
			return new ReturnT<String>(500, "请输入“负责人”");
		}
		if (StringUtils.isBlank(alarmEmail)) {
			return new ReturnT<String>(500, "请输入“报警邮件”");
		}
X
fresh  
xueli.xue 已提交
171 172 173 174
		if (glueSwitch==0 && StringUtils.isBlank(executorHandler)) {
			return new ReturnT<String>(500, "请输入“JobHandler”");
		}

X
coding  
xueli.xue 已提交
175 176 177 178 179 180 181 182
		// childJobKey valid
		if (StringUtils.isNotBlank(childJobKey)) {
			String[] childJobKeys = childJobKey.split(",");
			for (String childJobKeyItem: childJobKeys) {
				String[] childJobKeyArr = childJobKeyItem.split("_");
				if (childJobKeyArr.length!=2) {
					return new ReturnT<String>(500, MessageFormat.format("子任务Key({0})格式错误", childJobKeyItem));
				}
183
				XxlJobInfo childJobInfo = xxlJobInfoDao.load(Integer.valueOf(childJobKeyArr[0]), childJobKeyArr[1]);
X
coding  
xueli.xue 已提交
184 185 186 187 188 189
				if (childJobInfo==null) {
					return new ReturnT<String>(500, MessageFormat.format("子任务Key({0})无效", childJobKeyItem));
				}
			}
		}

X
fresh  
xueli.xue 已提交
190
		// stage job info
191
		XxlJobInfo jobInfo = xxlJobInfoDao.load(jobGroup, jobName);
X
xueli.xue 已提交
192
		jobInfo.setJobCron(jobCron);
X
fresh  
xueli.xue 已提交
193
		jobInfo.setJobDesc(jobDesc);
194 195
		jobInfo.setAuthor(author);
		jobInfo.setAlarmEmail(alarmEmail);
X
fresh  
xueli.xue 已提交
196
		jobInfo.setExecutorHandler(executorHandler);
197
		jobInfo.setExecutorParam(executorParam);
X
fresh  
xueli.xue 已提交
198
		jobInfo.setGlueSwitch(glueSwitch);
199
		jobInfo.setChildJobKey(childJobKey);
200 201 202
		
		try {
			// fresh quartz
203
			boolean ret = XxlJobDynamicScheduler.rescheduleJob(String.valueOf(jobGroup), jobName, jobCron);
X
fresh  
xueli.xue 已提交
204 205 206 207 208 209
			if (ret) {
				xxlJobInfoDao.update(jobInfo);
				return ReturnT.SUCCESS;
			} else {
				return new ReturnT<String>(500, "更新任务失败");
			}
210
		} catch (SchedulerException e) {
X
fresh  
xueli.xue 已提交
211
			logger.error("", e);
212 213 214 215 216
		}
		return ReturnT.FAIL;
	}

	@Override
217
	public ReturnT<String> remove(int jobGroup, String jobName) {
218
		try {
219
			XxlJobDynamicScheduler.removeJob(jobName, String.valueOf(jobGroup));
220 221 222 223 224 225 226 227 228 229 230
			xxlJobInfoDao.delete(jobGroup, jobName);
			xxlJobLogDao.delete(jobGroup, jobName);
			xxlJobLogGlueDao.delete(jobGroup, jobName);
			return ReturnT.SUCCESS;
		} catch (SchedulerException e) {
			e.printStackTrace();
		}
		return ReturnT.FAIL;
	}

	@Override
231
	public ReturnT<String> pause(int jobGroup, String jobName) {
232
		try {
233
			XxlJobDynamicScheduler.pauseJob(jobName, String.valueOf(jobGroup));	// jobStatus do not store
234 235 236 237 238 239 240 241
			return ReturnT.SUCCESS;
		} catch (SchedulerException e) {
			e.printStackTrace();
			return ReturnT.FAIL;
		}
	}

	@Override
242
	public ReturnT<String> resume(int jobGroup, String jobName) {
243
		try {
244
			XxlJobDynamicScheduler.resumeJob(jobName, String.valueOf(jobGroup));
245 246 247 248 249 250 251 252
			return ReturnT.SUCCESS;
		} catch (SchedulerException e) {
			e.printStackTrace();
			return ReturnT.FAIL;
		}
	}

	@Override
253
	public ReturnT<String> triggerJob(int jobGroup, String jobName) {
254
		try {
255
			XxlJobDynamicScheduler.triggerJob(jobName, String.valueOf(jobGroup));
256 257 258 259 260 261 262 263
			return ReturnT.SUCCESS;
		} catch (SchedulerException e) {
			e.printStackTrace();
			return ReturnT.FAIL;
		}
	}
	
}