Stop running status collection when the project is closed gracefully (#918)

1.4.3
chen.ma 2 years ago
parent 0be201f948
commit b483b29beb

@ -28,6 +28,7 @@ import cn.hippo4j.monitor.base.DynamicThreadPoolMonitor;
import cn.hippo4j.monitor.base.ThreadPoolMonitor; import cn.hippo4j.monitor.base.ThreadPoolMonitor;
import lombok.RequiredArgsConstructor; import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.DisposableBean;
import org.springframework.boot.ApplicationArguments; import org.springframework.boot.ApplicationArguments;
import org.springframework.boot.ApplicationRunner; import org.springframework.boot.ApplicationRunner;
@ -35,6 +36,7 @@ import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.Collection; import java.util.Collection;
import java.util.List; import java.util.List;
import java.util.Optional;
import java.util.concurrent.ScheduledThreadPoolExecutor; import java.util.concurrent.ScheduledThreadPoolExecutor;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
@ -45,11 +47,11 @@ import static cn.hippo4j.core.executor.manage.GlobalThreadPoolManage.getThreadPo
*/ */
@Slf4j @Slf4j
@RequiredArgsConstructor @RequiredArgsConstructor
public class ThreadPoolMonitorExecutor implements ApplicationRunner { public class ThreadPoolMonitorExecutor implements ApplicationRunner, DisposableBean {
private final BootstrapConfigProperties properties; private final BootstrapConfigProperties properties;
private ScheduledThreadPoolExecutor collectExecutor; private ScheduledThreadPoolExecutor collectScheduledExecutor;
private List<ThreadPoolMonitor> threadPoolMonitors; private List<ThreadPoolMonitor> threadPoolMonitors;
@ -64,7 +66,7 @@ public class ThreadPoolMonitorExecutor implements ApplicationRunner {
} }
log.info("Start monitoring the running status of dynamic thread pool."); log.info("Start monitoring the running status of dynamic thread pool.");
threadPoolMonitors = new ArrayList<>(); threadPoolMonitors = new ArrayList<>();
collectExecutor = new ScheduledThreadPoolExecutor( collectScheduledExecutor = new ScheduledThreadPoolExecutor(
new Integer(1), new Integer(1),
ThreadFactoryBuilder.builder().daemon(true).prefix("client.scheduled.collect.data").build()); ThreadFactoryBuilder.builder().daemon(true).prefix("client.scheduled.collect.data").build());
// Get dynamic thread pool monitoring component. // Get dynamic thread pool monitoring component.
@ -74,7 +76,7 @@ public class ThreadPoolMonitorExecutor implements ApplicationRunner {
DynamicThreadPoolServiceLoader.getSingletonServiceInstances(DynamicThreadPoolMonitor.class); DynamicThreadPoolServiceLoader.getSingletonServiceInstances(DynamicThreadPoolMonitor.class);
dynamicThreadPoolMonitors.stream().filter(each -> collectTypes.contains(each.getType())).forEach(each -> threadPoolMonitors.add(each)); dynamicThreadPoolMonitors.stream().filter(each -> collectTypes.contains(each.getType())).forEach(each -> threadPoolMonitors.add(each));
// Execute dynamic thread pool monitoring component. // Execute dynamic thread pool monitoring component.
collectExecutor.scheduleWithFixedDelay( collectScheduledExecutor.scheduleWithFixedDelay(
() -> scheduleRunnable(), () -> scheduleRunnable(),
properties.getInitialDelay(), properties.getInitialDelay(),
properties.getCollectInterval(), properties.getCollectInterval(),
@ -93,4 +95,9 @@ public class ThreadPoolMonitorExecutor implements ApplicationRunner {
} }
} }
} }
@Override
public void destroy() throws Exception {
Optional.ofNullable(collectScheduledExecutor).ifPresent(each -> each.shutdown());
}
} }

Loading…
Cancel
Save