WangHan
2024-09-12 d5855a4926926698b740bc6c7ba489de47adb68b
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
package tech.powerjob.worker.test.processors.demo;
 
import tech.powerjob.worker.core.processor.ProcessResult;
import tech.powerjob.worker.core.processor.TaskContext;
import tech.powerjob.worker.core.processor.TaskResult;
import tech.powerjob.worker.core.processor.sdk.BroadcastProcessor;
 
import java.util.List;
 
/**
 * 示例-广播执行处理器
 *
 * @author tjq
 * @since 2020/4/15
 */
public class BroadcastProcessorDemo implements BroadcastProcessor {
 
    @Override
    public ProcessResult preProcess(TaskContext taskContext) throws Exception {
        // 预执行,会在所有 worker 执行 process 方法前调用
        return new ProcessResult(true, "init success");
    }
 
    @Override
    public ProcessResult process(TaskContext context) throws Exception {
        // 撰写整个worker集群都会执行的代码逻辑
        return new ProcessResult(true, "release resource success");
    }
 
    @Override
    public ProcessResult postProcess(TaskContext taskContext, List<TaskResult> taskResults) throws Exception {
 
        // taskResults 存储了所有worker执行的结果(包括preProcess)
 
        // 收尾,会在所有 worker 执行完毕 process 方法后调用,该结果将作为最终的执行结果在
        return new ProcessResult(true, "process success");
    }
 
}