liulin
2024-11-24 af410d1cde67d4656c9922ff4d846cac0740e3b2
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
package com.lunhan.xxx.service.quartz;
 
import com.google.gson.JsonElement;
import com.google.gson.JsonObject;
import com.google.gson.JsonParser;
import com.lunhan.xxx.common.ConstantFactory;
import com.lunhan.xxx.common.ExecutedResult;
import com.lunhan.xxx.common.util.LocalDateTimeUtil;
import com.lunhan.xxx.common.util.NumericUtil;
import com.lunhan.xxx.common.util.StringUtil;
import com.lunhan.xxx.repository.impl.QuartzTaskErrorMapperImpl;
import com.lunhan.xxx.repository.impl.QuartzTaskRecordMapperImpl;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
 
import java.lang.reflect.Method;
import java.time.LocalDateTime;
import java.util.Objects;
 
@Service
public class QuartzExecutor {
    private static Logger logger = LoggerFactory.getLogger(QuartzExecutor.class);
 
    @Autowired
    private QuartzTaskRecordMapperImpl taskRecordsDao;
    @Autowired
    private QuartzTaskErrorMapperImpl taskErrorsDao;
 
    /**
     * 执行job
     * @param executorName 执行器名称(方法名)
     * @param jobParameter 执行参数
     */
    public ExecutedResult<String> execute(String executorName, String jobParameter) {
        try {
            // 根据执行器key,查找执行器的方法(入参:String jobParameter,返参:ExecutedResult<String>)
            Method method = QuartzExecutor.class.getMethod(executorName, String.class);
            return (ExecutedResult<String>)method.invoke(this, jobParameter);
        } catch (Exception e) {
            return ExecutedResult.failed(e.toString());
        }
    }
 
    /***
     * job执行器-清理任务调度日志
     * @param jobParameter 执行参数
     */
    public ExecutedResult<String> clearQuartzLog(String jobParameter) {
        try {
            int keepDays = ConstantFactory.NUM15;
            if (StringUtil.isNotNullOrEmpty(jobParameter)) {
                JsonElement element = new JsonParser().parse(jobParameter);
                if (Objects.nonNull(element) && !element.isJsonNull()) {
                    JsonObject data = element.getAsJsonObject();
                    if (data.has("keepDays") && !data.get("keepDays").isJsonNull()) {
                        keepDays = NumericUtil.tryParseInt(data.get("keepDays").getAsString(), ConstantFactory.NUM15);
                    }
                }
            }
            LocalDateTime today = LocalDateTimeUtil.todayFirst();
            LocalDateTime limitDate = LocalDateTimeUtil.dateTimeAddDay(today, -1L * keepDays);
 
            taskRecordsDao.clear4DateTime(LocalDateTimeUtil.getTimeStamp(limitDate).getTime());
            taskErrorsDao.clear4DateTime(LocalDateTimeUtil.getTimeStamp(limitDate).getTime());
            return ExecutedResult.success();
        } catch (Exception e) {
            return ExecutedResult.failed(e.toString());
        }
    }
}