package tech.powerjob.worker.core.tracker.manager; import com.google.common.collect.Maps; import tech.powerjob.worker.core.tracker.task.light.LightTaskTracker; import java.util.Map; import java.util.function.Function; /** * @author Echo009 * @since 2022/9/23 */ public class LightTaskTrackerManager { public static final double OVERLOAD_FACTOR = 1.3d; private static final Map INSTANCE_ID_2_TASK_TRACKER = Maps.newConcurrentMap(); public static LightTaskTracker getTaskTracker(Long instanceId) { return INSTANCE_ID_2_TASK_TRACKER.get(instanceId); } public static void removeTaskTracker(Long instanceId) { // 忽略印度的 IDE 警告,这个判断非常有用!!!不加这个判断会导致:如果创建 TT(先执行 computeIfAbsent 正在将TT添加到 HashMap) 时报错,TT 主动调用 destroy 销毁(从 HashMap移除该 TT)时死锁 if (INSTANCE_ID_2_TASK_TRACKER.containsKey(instanceId)) { INSTANCE_ID_2_TASK_TRACKER.remove(instanceId); } } public static void atomicCreateTaskTracker(Long instanceId, Function creator) { INSTANCE_ID_2_TASK_TRACKER.computeIfAbsent(instanceId, creator); } public static int currentTaskTrackerSize(){ return INSTANCE_ID_2_TASK_TRACKER.size(); } }