diff --git a/solr/CHANGES.txt b/solr/CHANGES.txt index da4af08cf41..cb7f0888ac4 100644 --- a/solr/CHANGES.txt +++ b/solr/CHANGES.txt @@ -341,6 +341,9 @@ Bug Fixes * SOLR-5564: hl.maxAlternateFieldLength should apply to original field when fallback is attempted (janhoy) +* SOLR-5608: Don't allow a closed SolrCore to publish state to ZooKeeper. + (Mark Miller, Shawn Heisey) + Optimizations ---------------------- diff --git a/solr/core/src/java/org/apache/solr/cloud/ZkController.java b/solr/core/src/java/org/apache/solr/cloud/ZkController.java index 7da73667b3d..9a4fd134b43 100644 --- a/solr/core/src/java/org/apache/solr/cloud/ZkController.java +++ b/solr/core/src/java/org/apache/solr/cloud/ZkController.java @@ -982,10 +982,27 @@ public final class ZkController { publish(cd, state, true); } + public void publish(final CoreDescriptor cd, final String state, boolean updateLastState) throws KeeperException, InterruptedException { + publish(cd, state, true, false); + } + /** * Publish core state to overseer. */ - public void publish(final CoreDescriptor cd, final String state, boolean updateLastState) throws KeeperException, InterruptedException { + public void publish(final CoreDescriptor cd, final String state, boolean updateLastState, boolean forcePublish) throws KeeperException, InterruptedException { + if (!forcePublish) { + SolrCore core = cc.getCore(cd.getName()); + if (core == null) { + return; + } + try { + if (core.isClosed()) { + return; + } + } finally { + core.close(); + } + } log.info("publishing core={} state={}", cd.getName(), state); //System.out.println(Thread.currentThread().getStackTrace()[3]); Integer numShards = cd.getCloudDescriptor().getNumShards(); @@ -1341,7 +1358,7 @@ public final class ZkController { cloudDesc.setCoreNodeName(coreNodeName); } - publish(cd, ZkStateReader.DOWN, false); + publish(cd, ZkStateReader.DOWN, false, true); } catch (KeeperException e) { log.error("", e); throw new ZooKeeperException(SolrException.ErrorCode.SERVER_ERROR, "", e);