mirror of https://github.com/apache/lucene.git
Merge remote-tracking branch 'refs/remotes/origin/master'
This commit is contained in:
commit
629081f950
|
@ -102,6 +102,9 @@ Bug Fixes
|
||||||
|
|
||||||
* SOLR-11807: Restoring collection now treats maxShardsPerNode=-1 as unlimited (Varun Thacker)
|
* SOLR-11807: Restoring collection now treats maxShardsPerNode=-1 as unlimited (Varun Thacker)
|
||||||
|
|
||||||
|
* SOLR-12413: If Zookeeper was pre-loaded with data before first-use, then the aliases information would be ignored.
|
||||||
|
(David Smiley, Gaël Jourdan, Gus Heck)
|
||||||
|
|
||||||
Optimizations
|
Optimizations
|
||||||
----------------------
|
----------------------
|
||||||
|
|
||||||
|
|
|
@ -39,10 +39,10 @@ public class Aliases {
|
||||||
/**
|
/**
|
||||||
* An empty, minimal Aliases primarily used to support the non-cloud solr use cases. Not normally useful
|
* An empty, minimal Aliases primarily used to support the non-cloud solr use cases. Not normally useful
|
||||||
* in cloud situations where the version of the node needs to be tracked even if all aliases are removed.
|
* in cloud situations where the version of the node needs to be tracked even if all aliases are removed.
|
||||||
* A version of 0 is provided rather than -1 to minimize the possibility that if this is used in a cloud
|
* The -1 version makes it subordinate to any real version, and furthermore we never "set" this EMPTY instance
|
||||||
* instance data is written without version checking.
|
* into ZK.
|
||||||
*/
|
*/
|
||||||
public static final Aliases EMPTY = new Aliases(Collections.emptyMap(), Collections.emptyMap(), 0);
|
public static final Aliases EMPTY = new Aliases(Collections.emptyMap(), Collections.emptyMap(), -1);
|
||||||
|
|
||||||
// These two constants correspond to the top level elements in aliases.json. The first one denotes
|
// These two constants correspond to the top level elements in aliases.json. The first one denotes
|
||||||
// a section containing a list of aliases and their attendant collections, the second contains a list of
|
// a section containing a list of aliases and their attendant collections, the second contains a list of
|
||||||
|
|
|
@ -1698,6 +1698,19 @@ public class ZkStateReader implements Closeable {
|
||||||
* The caller should understand it's possible the aliases has further changed if it examines it.
|
* The caller should understand it's possible the aliases has further changed if it examines it.
|
||||||
*/
|
*/
|
||||||
public void applyModificationAndExportToZk(UnaryOperator<Aliases> op) {
|
public void applyModificationAndExportToZk(UnaryOperator<Aliases> op) {
|
||||||
|
// The current aliases hasn't been update()'ed yet -- which is impossible? Any way just update it first.
|
||||||
|
if (aliases.getZNodeVersion() == -1) {
|
||||||
|
try {
|
||||||
|
boolean updated = update();
|
||||||
|
assert updated;
|
||||||
|
} catch (InterruptedException e) {
|
||||||
|
Thread.currentThread().interrupt();
|
||||||
|
throw new ZooKeeperException(ErrorCode.SERVER_ERROR, e.toString(), e);
|
||||||
|
} catch (KeeperException e) {
|
||||||
|
throw new ZooKeeperException(ErrorCode.SERVER_ERROR, e.toString(), e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
final long deadlineNanos = System.nanoTime() + TimeUnit.SECONDS.toNanos(30);
|
final long deadlineNanos = System.nanoTime() + TimeUnit.SECONDS.toNanos(30);
|
||||||
// note: triesLeft tuning is based on ConcurrentCreateRoutedAliasTest
|
// note: triesLeft tuning is based on ConcurrentCreateRoutedAliasTest
|
||||||
for (int triesLeft = 30; triesLeft > 0; triesLeft--) {
|
for (int triesLeft = 30; triesLeft > 0; triesLeft--) {
|
||||||
|
@ -1769,6 +1782,7 @@ public class ZkStateReader implements Closeable {
|
||||||
// note: it'd be nice to avoid possibly needlessly parsing if we don't update aliases but not a big deal
|
// note: it'd be nice to avoid possibly needlessly parsing if we don't update aliases but not a big deal
|
||||||
setIfNewer(Aliases.fromJSON(data, stat.getVersion()));
|
setIfNewer(Aliases.fromJSON(data, stat.getVersion()));
|
||||||
} catch (KeeperException.ConnectionLossException | KeeperException.SessionExpiredException e) {
|
} catch (KeeperException.ConnectionLossException | KeeperException.SessionExpiredException e) {
|
||||||
|
// note: aliases.json is required to be present
|
||||||
LOG.warn("ZooKeeper watch triggered, but Solr cannot talk to ZK: [{}]", e.getMessage());
|
LOG.warn("ZooKeeper watch triggered, but Solr cannot talk to ZK: [{}]", e.getMessage());
|
||||||
} catch (KeeperException e) {
|
} catch (KeeperException e) {
|
||||||
LOG.error("A ZK error has occurred", e);
|
LOG.error("A ZK error has occurred", e);
|
||||||
|
@ -1786,6 +1800,7 @@ public class ZkStateReader implements Closeable {
|
||||||
* @param newAliases the potentially newer version of Aliases
|
* @param newAliases the potentially newer version of Aliases
|
||||||
*/
|
*/
|
||||||
private boolean setIfNewer(Aliases newAliases) {
|
private boolean setIfNewer(Aliases newAliases) {
|
||||||
|
assert newAliases.getZNodeVersion() >= 0;
|
||||||
synchronized (this) {
|
synchronized (this) {
|
||||||
int cmp = Integer.compare(aliases.getZNodeVersion(), newAliases.getZNodeVersion());
|
int cmp = Integer.compare(aliases.getZNodeVersion(), newAliases.getZNodeVersion());
|
||||||
if (cmp < 0) {
|
if (cmp < 0) {
|
||||||
|
|
Loading…
Reference in New Issue