SOLR-14651: Metrics History could disable better ()

* SolrRrdBackendFactory should not be created if history is disabled
* Disable MetricsHistoryHandler by default in tests
* Await shutdown of all executors
This commit is contained in:
David Smiley 2020-07-28 16:46:27 -04:00 committed by GitHub
parent 5d46361024
commit a3624029ad
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 27 additions and 26 deletions
solr
CHANGES.txt
core/src/java/org/apache/solr
solrj/src/java/org/apache/solr/common/util
test-framework/src/java/org/apache/solr/util

View File

@ -131,6 +131,9 @@ Improvements
* SOLR-13205: Prevent StringIndexOutOfBoundsException when parsing field names in SolrQueryParserBase * SOLR-13205: Prevent StringIndexOutOfBoundsException when parsing field names in SolrQueryParserBase
(pramodkumar9 via Jason Gerlowski) (pramodkumar9 via Jason Gerlowski)
* SOLR-14651: The MetricsHistoryHandler can more completely disable itself when you tell it to.
Also, it now shuts down more thoroughly. (David Smiley)
Optimizations Optimizations
--------------------- ---------------------

View File

@ -893,7 +893,7 @@ public class CoreContainer {
Map<String, Object> initArgs; Map<String, Object> initArgs;
if (plugin != null && plugin.initArgs != null) { if (plugin != null && plugin.initArgs != null) {
initArgs = plugin.initArgs.asMap(5); initArgs = plugin.initArgs.asMap(5);
initArgs.put(MetricsHistoryHandler.ENABLE_PROP, plugin.isEnabled()); initArgs.putIfAbsent(MetricsHistoryHandler.ENABLE_PROP, plugin.isEnabled());
} else { } else {
initArgs = new HashMap<>(); initArgs = new HashMap<>();
} }
@ -919,12 +919,8 @@ public class CoreContainer {
} }
}; };
// enable local metrics unless specifically set otherwise // enable local metrics unless specifically set otherwise
if (!initArgs.containsKey(MetricsHistoryHandler.ENABLE_NODES_PROP)) { initArgs.putIfAbsent(MetricsHistoryHandler.ENABLE_NODES_PROP, true);
initArgs.put(MetricsHistoryHandler.ENABLE_NODES_PROP, true); initArgs.putIfAbsent(MetricsHistoryHandler.ENABLE_REPLICAS_PROP, true);
}
if (!initArgs.containsKey(MetricsHistoryHandler.ENABLE_REPLICAS_PROP)) {
initArgs.put(MetricsHistoryHandler.ENABLE_REPLICAS_PROP, true);
}
} }
metricsHistoryHandler = new MetricsHistoryHandler(name, metricsHandler, metricsHistoryHandler = new MetricsHistoryHandler(name, metricsHandler,
client, cloudManager, initArgs); client, cloudManager, initArgs);

View File

@ -207,8 +207,6 @@ public class MetricsHistoryHandler extends RequestHandlerBase implements Permiss
this.metricsHandler = metricsHandler; this.metricsHandler = metricsHandler;
this.cloudManager = cloudManager; this.cloudManager = cloudManager;
this.timeSource = cloudManager != null ? cloudManager.getTimeSource() : TimeSource.NANO_TIME; this.timeSource = cloudManager != null ? cloudManager.getTimeSource() : TimeSource.NANO_TIME;
factory = new SolrRrdBackendFactory(solrClient, CollectionAdminParams.SYSTEM_COLL,
syncPeriod, this.timeSource);
counters.put(Group.core.toString(), DEFAULT_CORE_COUNTERS); counters.put(Group.core.toString(), DEFAULT_CORE_COUNTERS);
counters.put(Group.node.toString(), Collections.emptyList()); counters.put(Group.node.toString(), Collections.emptyList());
@ -228,6 +226,9 @@ public class MetricsHistoryHandler extends RequestHandlerBase implements Permiss
} }
if (enable) { if (enable) {
factory = new SolrRrdBackendFactory(solrClient, CollectionAdminParams.SYSTEM_COLL,
syncPeriod, this.timeSource);
collectService = (ScheduledThreadPoolExecutor) Executors.newScheduledThreadPool(1, collectService = (ScheduledThreadPoolExecutor) Executors.newScheduledThreadPool(1,
new SolrNamedThreadFactory("MetricsHistoryHandler")); new SolrNamedThreadFactory("MetricsHistoryHandler"));
collectService.setRemoveOnCancelPolicy(true); collectService.setRemoveOnCancelPolicy(true);
@ -237,6 +238,8 @@ public class MetricsHistoryHandler extends RequestHandlerBase implements Permiss
timeSource.convertDelay(TimeUnit.SECONDS, collectPeriod, TimeUnit.MILLISECONDS), timeSource.convertDelay(TimeUnit.SECONDS, collectPeriod, TimeUnit.MILLISECONDS),
TimeUnit.MILLISECONDS); TimeUnit.MILLISECONDS);
checkSystemCollection(); checkSystemCollection();
} else {
factory = null;
} }
} }
@ -654,19 +657,7 @@ public class MetricsHistoryHandler extends RequestHandlerBase implements Permiss
if (log.isDebugEnabled()) { if (log.isDebugEnabled()) {
log.debug("Closing {}", hashCode()); log.debug("Closing {}", hashCode());
} }
if (collectService != null) { ExecutorUtil.shutdownNowAndAwaitTermination(collectService);
boolean shutdown = false;
while (!shutdown) {
try {
// Wait a while for existing tasks to terminate
collectService.shutdownNow();
shutdown = collectService.awaitTermination(5, TimeUnit.SECONDS);
} catch (InterruptedException ie) {
// Preserve interrupt status
Thread.currentThread().interrupt();
}
}
}
if (factory != null) { if (factory != null) {
factory.close(); factory.close();
} }

View File

@ -44,6 +44,7 @@ import org.apache.solr.common.SolrInputDocument;
import org.apache.solr.common.params.CollectionAdminParams; import org.apache.solr.common.params.CollectionAdminParams;
import org.apache.solr.common.params.CommonParams; import org.apache.solr.common.params.CommonParams;
import org.apache.solr.common.params.ModifiableSolrParams; import org.apache.solr.common.params.ModifiableSolrParams;
import org.apache.solr.common.util.ExecutorUtil;
import org.apache.solr.common.util.IOUtils; import org.apache.solr.common.util.IOUtils;
import org.apache.solr.common.util.Pair; import org.apache.solr.common.util.Pair;
import org.apache.solr.common.util.TimeSource; import org.apache.solr.common.util.TimeSource;
@ -459,9 +460,9 @@ public class SolrRrdBackendFactory extends RrdBackendFactory implements SolrClos
log.debug("Closing {}", hashCode()); log.debug("Closing {}", hashCode());
} }
closed = true; closed = true;
backends.forEach((p, b) -> IOUtils.closeQuietly(b)); backends.values().forEach(IOUtils::closeQuietly);
backends.clear(); backends.clear();
syncService.shutdownNow(); ExecutorUtil.shutdownNowAndAwaitTermination(syncService);
syncService = null; syncService = null;
} }
} }

View File

@ -72,11 +72,17 @@ public class ExecutorUtil {
} }
public static void shutdownAndAwaitTermination(ExecutorService pool) { public static void shutdownAndAwaitTermination(ExecutorService pool) {
if(pool == null) return; if (pool == null) return;
pool.shutdown(); // Disable new tasks from being submitted pool.shutdown(); // Disable new tasks from being submitted
awaitTermination(pool); awaitTermination(pool);
} }
public static void shutdownNowAndAwaitTermination(ExecutorService pool) {
if (pool == null) return;
pool.shutdownNow(); // Disable new tasks from being submitted; interrupt existing tasks
awaitTermination(pool);
}
public static void awaitTermination(ExecutorService pool) { public static void awaitTermination(ExecutorService pool) {
boolean shutdown = false; boolean shutdown = false;
while (!shutdown) { while (!shutdown) {

View File

@ -21,6 +21,7 @@ import java.io.IOException;
import java.io.StringWriter; import java.io.StringWriter;
import java.nio.charset.StandardCharsets; import java.nio.charset.StandardCharsets;
import java.nio.file.Path; import java.nio.file.Path;
import java.util.Collections;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
@ -191,7 +192,10 @@ public class TestHarness extends BaseTestHarness {
attributes.put("class", SolrJmxReporter.class.getName()); attributes.put("class", SolrJmxReporter.class.getName());
PluginInfo defaultPlugin = new PluginInfo("reporter", attributes); PluginInfo defaultPlugin = new PluginInfo("reporter", attributes);
MetricsConfig metricsConfig = new MetricsConfig.MetricsConfigBuilder() MetricsConfig metricsConfig = new MetricsConfig.MetricsConfigBuilder()
.setMetricReporterPlugins(new PluginInfo[] {defaultPlugin}) .setMetricReporterPlugins(new PluginInfo[]{defaultPlugin})
.setHistoryHandler(
Boolean.getBoolean("metricsHistory")
? null : new PluginInfo("typeUnused", Collections.singletonMap("enable", "false")))
.build(); .build();
return new NodeConfig.NodeConfigBuilder("testNode", solrHome) return new NodeConfig.NodeConfigBuilder("testNode", solrHome)