mirror of https://github.com/apache/lucene.git
SOLR-9181: Add some logging to ZkStateReader to try and debug test failures
This commit is contained in:
parent
8653be9a5b
commit
e6e0765e86
|
@ -16,6 +16,10 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.solr.cloud.overseer;
|
package org.apache.solr.cloud.overseer;
|
||||||
|
|
||||||
|
import java.lang.invoke.MethodHandles;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
import org.apache.lucene.util.IOUtils;
|
import org.apache.lucene.util.IOUtils;
|
||||||
import org.apache.solr.SolrTestCaseJ4;
|
import org.apache.solr.SolrTestCaseJ4;
|
||||||
import org.apache.solr.cloud.AbstractZkTestCase;
|
import org.apache.solr.cloud.AbstractZkTestCase;
|
||||||
|
@ -31,12 +35,13 @@ import org.apache.solr.common.cloud.SolrZkClient;
|
||||||
import org.apache.solr.common.cloud.ZkStateReader;
|
import org.apache.solr.common.cloud.ZkStateReader;
|
||||||
import org.apache.solr.common.util.Utils;
|
import org.apache.solr.common.util.Utils;
|
||||||
import org.apache.zookeeper.KeeperException;
|
import org.apache.zookeeper.KeeperException;
|
||||||
|
import org.slf4j.Logger;
|
||||||
import java.util.HashMap;
|
import org.slf4j.LoggerFactory;
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
public class ZkStateWriterTest extends SolrTestCaseJ4 {
|
public class ZkStateWriterTest extends SolrTestCaseJ4 {
|
||||||
|
|
||||||
|
private static final Logger log = LoggerFactory.getLogger(MethodHandles.lookup().lookupClass());
|
||||||
|
|
||||||
public void testZkStateWriterBatching() throws Exception {
|
public void testZkStateWriterBatching() throws Exception {
|
||||||
String zkDir = createTempDir("testZkStateWriterBatching").toFile().getAbsolutePath();
|
String zkDir = createTempDir("testZkStateWriterBatching").toFile().getAbsolutePath();
|
||||||
|
|
||||||
|
@ -319,6 +324,7 @@ public class ZkStateWriterTest extends SolrTestCaseJ4 {
|
||||||
// get the most up-to-date state
|
// get the most up-to-date state
|
||||||
reader.forceUpdateCollection("c2");
|
reader.forceUpdateCollection("c2");
|
||||||
state = reader.getClusterState();
|
state = reader.getClusterState();
|
||||||
|
log.info("Cluster state: {}", state);
|
||||||
assertTrue(state.hasCollection("c2"));
|
assertTrue(state.hasCollection("c2"));
|
||||||
assertEquals(sharedClusterStateVersion, (int) state.getZkClusterStateVersion());
|
assertEquals(sharedClusterStateVersion, (int) state.getZkClusterStateVersion());
|
||||||
assertEquals(stateFormat2Version + 1, state.getCollection("c2").getZNodeVersion());
|
assertEquals(stateFormat2Version + 1, state.getCollection("c2").getZNodeVersion());
|
||||||
|
|
|
@ -16,6 +16,24 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.solr.common.cloud;
|
package org.apache.solr.common.cloud;
|
||||||
|
|
||||||
|
import javax.xml.transform.OutputKeys;
|
||||||
|
import javax.xml.transform.Source;
|
||||||
|
import javax.xml.transform.Transformer;
|
||||||
|
import javax.xml.transform.TransformerFactory;
|
||||||
|
import javax.xml.transform.stream.StreamResult;
|
||||||
|
import javax.xml.transform.stream.StreamSource;
|
||||||
|
import java.io.Closeable;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.StringReader;
|
||||||
|
import java.io.StringWriter;
|
||||||
|
import java.lang.invoke.MethodHandles;
|
||||||
|
import java.nio.charset.StandardCharsets;
|
||||||
|
import java.nio.file.Path;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.concurrent.ExecutorService;
|
||||||
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
import org.apache.commons.io.FileUtils;
|
import org.apache.commons.io.FileUtils;
|
||||||
import org.apache.solr.client.solrj.SolrServerException;
|
import org.apache.solr.client.solrj.SolrServerException;
|
||||||
import org.apache.solr.common.SolrException;
|
import org.apache.solr.common.SolrException;
|
||||||
|
@ -38,25 +56,6 @@ import org.apache.zookeeper.data.Stat;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import javax.xml.transform.OutputKeys;
|
|
||||||
import javax.xml.transform.Source;
|
|
||||||
import javax.xml.transform.Transformer;
|
|
||||||
import javax.xml.transform.TransformerFactory;
|
|
||||||
import javax.xml.transform.stream.StreamResult;
|
|
||||||
import javax.xml.transform.stream.StreamSource;
|
|
||||||
|
|
||||||
import java.io.Closeable;
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.io.StringReader;
|
|
||||||
import java.io.StringWriter;
|
|
||||||
import java.lang.invoke.MethodHandles;
|
|
||||||
import java.nio.charset.StandardCharsets;
|
|
||||||
import java.nio.file.Path;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.concurrent.ExecutorService;
|
|
||||||
import java.util.regex.Pattern;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* All Solr ZooKeeper interactions should go through this class rather than
|
* All Solr ZooKeeper interactions should go through this class rather than
|
||||||
|
|
|
@ -290,6 +290,7 @@ public class ZkStateReader implements Closeable {
|
||||||
|
|
||||||
synchronized (getUpdateLock()) {
|
synchronized (getUpdateLock()) {
|
||||||
if (clusterState == null) {
|
if (clusterState == null) {
|
||||||
|
LOG.info("ClusterState watchers have not been initialized");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -297,6 +298,7 @@ public class ZkStateReader implements Closeable {
|
||||||
if (ref == null || legacyCollectionStates.containsKey(collection)) {
|
if (ref == null || legacyCollectionStates.containsKey(collection)) {
|
||||||
// We either don't know anything about this collection (maybe it's new?) or it's legacy.
|
// We either don't know anything about this collection (maybe it's new?) or it's legacy.
|
||||||
// First update the legacy cluster state.
|
// First update the legacy cluster state.
|
||||||
|
LOG.info("Checking legacy cluster state for collection {}", collection);
|
||||||
refreshLegacyClusterState(null);
|
refreshLegacyClusterState(null);
|
||||||
if (!legacyCollectionStates.containsKey(collection)) {
|
if (!legacyCollectionStates.containsKey(collection)) {
|
||||||
// No dice, see if a new collection just got created.
|
// No dice, see if a new collection just got created.
|
||||||
|
@ -307,6 +309,7 @@ public class ZkStateReader implements Closeable {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (ref.isLazilyLoaded()) {
|
} else if (ref.isLazilyLoaded()) {
|
||||||
|
LOG.info("Refreshing lazily-loaded state for collection {}", collection);
|
||||||
if (ref.get() != null) {
|
if (ref.get() != null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -314,6 +317,7 @@ public class ZkStateReader implements Closeable {
|
||||||
refreshLegacyClusterState(null);
|
refreshLegacyClusterState(null);
|
||||||
} else if (watchedCollectionStates.containsKey(collection)) {
|
} else if (watchedCollectionStates.containsKey(collection)) {
|
||||||
// Exists as a watched collection, force a refresh.
|
// Exists as a watched collection, force a refresh.
|
||||||
|
LOG.info("Forcing refresh of watched collection state for {}", collection);
|
||||||
DocCollection newState = fetchCollectionState(collection, null);
|
DocCollection newState = fetchCollectionState(collection, null);
|
||||||
if (updateWatchedCollection(collection, newState)) {
|
if (updateWatchedCollection(collection, newState)) {
|
||||||
constructState(Collections.singletonMap(collection, newState));
|
constructState(Collections.singletonMap(collection, newState));
|
||||||
|
|
Loading…
Reference in New Issue