|
16 | 16 |
|
17 | 17 | package org.springframework.boot.actuate.autoconfigure.metrics;
|
18 | 18 |
|
| 19 | +import java.util.List; |
| 20 | + |
19 | 21 | import io.micrometer.core.annotation.Timed;
|
20 | 22 | import io.micrometer.core.instrument.Clock;
|
| 23 | +import io.micrometer.core.instrument.MeterRegistry; |
21 | 24 | import io.micrometer.core.instrument.binder.MeterBinder;
|
22 | 25 | import io.micrometer.core.instrument.config.MeterFilter;
|
23 | 26 |
|
|
28 | 31 | import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
|
29 | 32 | import org.springframework.boot.context.properties.EnableConfigurationProperties;
|
30 | 33 | import org.springframework.context.ApplicationContext;
|
| 34 | +import org.springframework.context.SmartLifecycle; |
31 | 35 | import org.springframework.context.annotation.Bean;
|
32 | 36 | import org.springframework.core.annotation.Order;
|
33 | 37 |
|
|
36 | 40 | *
|
37 | 41 | * @author Jon Schneider
|
38 | 42 | * @author Stephane Nicoll
|
| 43 | + * @author Phil Webb |
| 44 | + * @author Moritz Halbritter |
39 | 45 | * @since 2.0.0
|
40 | 46 | */
|
41 | 47 | @AutoConfiguration(before = CompositeMeterRegistryAutoConfiguration.class)
|
@@ -64,4 +70,45 @@ public PropertiesMeterFilter propertiesMeterFilter(MetricsProperties properties)
|
64 | 70 | return new PropertiesMeterFilter(properties);
|
65 | 71 | }
|
66 | 72 |
|
| 73 | + @Bean |
| 74 | + MeterRegistryLifecycle meterRegistryLifecycle(ObjectProvider<MeterRegistry> meterRegistries) { |
| 75 | + return new MeterRegistryLifecycle(meterRegistries.orderedStream().toList()); |
| 76 | + } |
| 77 | + |
| 78 | + /** |
| 79 | + * Ensures that {@link MeterRegistry meter registries} are closed early in the |
| 80 | + * shutdown process. |
| 81 | + */ |
| 82 | + static class MeterRegistryLifecycle implements SmartLifecycle { |
| 83 | + |
| 84 | + private volatile boolean running; |
| 85 | + |
| 86 | + private final List<MeterRegistry> meterRegistries; |
| 87 | + |
| 88 | + MeterRegistryLifecycle(List<MeterRegistry> meterRegistries) { |
| 89 | + this.meterRegistries = meterRegistries; |
| 90 | + } |
| 91 | + |
| 92 | + @Override |
| 93 | + public void start() { |
| 94 | + this.running = true; |
| 95 | + } |
| 96 | + |
| 97 | + @Override |
| 98 | + public void stop() { |
| 99 | + this.running = false; |
| 100 | + this.meterRegistries.forEach((registry) -> { |
| 101 | + if (!registry.isClosed()) { |
| 102 | + registry.close(); |
| 103 | + } |
| 104 | + }); |
| 105 | + } |
| 106 | + |
| 107 | + @Override |
| 108 | + public boolean isRunning() { |
| 109 | + return this.running; |
| 110 | + } |
| 111 | + |
| 112 | + } |
| 113 | + |
67 | 114 | }
|
0 commit comments