Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Revert "Make NodeEnvironment.indexPaths singular (#72438)" #79011

Merged
merged 1 commit into from
Oct 13, 2021
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@
import org.elasticsearch.test.InternalTestCluster.RestartCallback;

import java.nio.file.Files;
import java.nio.file.Path;
import java.util.List;
import java.util.Map;

Expand Down Expand Up @@ -179,7 +180,12 @@ protected void assertIndexInMetaState(final String nodeName, final String indexN

private boolean indexDirectoryExists(String nodeName, Index index) {
NodeEnvironment nodeEnv = ((InternalTestCluster) cluster()).getInstance(NodeEnvironment.class, nodeName);
return Files.exists(nodeEnv.indexPath(index));
for (Path path : nodeEnv.indexPaths(index)) {
if (Files.exists(path)) {
return true;
}
}
return false;
}

private ImmutableOpenMap<String, IndexMetadata> getIndicesMetadataOnNode(String nodeName) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -452,7 +452,9 @@ public void onFailure(Exception e) {

private Path indexDirectory(String server, Index index) {
NodeEnvironment env = internalCluster().getInstance(NodeEnvironment.class, server);
return env.indexPath(index);
final Path[] paths = env.indexPaths(index);
assert paths.length == 1;
return paths[0];
}

private Path shardDirectory(String server, Index index, int shard) {
Expand Down
16 changes: 10 additions & 6 deletions server/src/main/java/org/elasticsearch/env/NodeEnvironment.java
Original file line number Diff line number Diff line change
Expand Up @@ -694,10 +694,10 @@ public void deleteIndexDirectorySafe(
* @param indexSettings settings for the index being deleted
*/
public void deleteIndexDirectoryUnderLock(Index index, IndexSettings indexSettings, Consumer<Path[]> listener) throws IOException {
final Path indexPath = indexPath(index);
logger.trace("deleting index {} directory: [{}]", index, indexPath);
listener.accept(new Path[] { indexPath });
IOUtils.rm(indexPath);
final Path[] indexPaths = indexPaths(index);
logger.trace("deleting index {} directory, paths({}): [{}]", index, indexPaths.length, indexPaths);
listener.accept(indexPaths);
IOUtils.rm(indexPaths);
if (indexSettings.hasCustomDataPath()) {
Path customLocation = resolveIndexCustomLocation(indexSettings.customDataPath(), index.getUUID());
logger.trace("deleting custom index {} directory [{}]", index, customLocation);
Expand Down Expand Up @@ -941,9 +941,13 @@ public NodePath[] nodePaths() {
/**
* Returns all index paths.
*/
public Path indexPath(Index index) {
public Path[] indexPaths(Index index) {
assertEnvIsLocked();
return nodePaths[0].resolve(index);
Path[] indexPaths = new Path[nodePaths.length];
for (int i = 0; i < nodePaths.length; i++) {
indexPaths[i] = nodePaths[i].resolve(index);
}
return indexPaths;
}


Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -142,7 +142,7 @@ private Tuple<Manifest, Metadata> loadFullStateBWC() throws IOException {
*/
@Nullable
public IndexMetadata loadIndexState(Index index) throws IOException {
return INDEX_METADATA_FORMAT.loadLatestState(logger, namedXContentRegistry, nodeEnv.indexPath(index));
return INDEX_METADATA_FORMAT.loadLatestState(logger, namedXContentRegistry, nodeEnv.indexPaths(index));
}

/**
Expand Down Expand Up @@ -205,7 +205,7 @@ public long writeIndex(String reason, IndexMetadata indexMetadata) throws WriteS
logger.trace("[{}] writing state, reason [{}]", index, reason);
try {
long generation = INDEX_METADATA_FORMAT.write(indexMetadata,
nodeEnv.indexPath(indexMetadata.getIndex()));
nodeEnv.indexPaths(indexMetadata.getIndex()));
logger.trace("[{}] state written", index);
return generation;
} catch (WriteStateException ex) {
Expand Down Expand Up @@ -246,7 +246,7 @@ void cleanupGlobalState(long currentGeneration) {
* @param currentGeneration current state generation to keep in the index directory.
*/
public void cleanupIndex(Index index, long currentGeneration) {
INDEX_METADATA_FORMAT.cleanupOldFiles(currentGeneration, nodeEnv.indexPath(index));
INDEX_METADATA_FORMAT.cleanupOldFiles(currentGeneration, nodeEnv.indexPaths(index));
}

/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -318,7 +318,7 @@ protected Directory newDirectory(Path dir) throws IOException {
* @param currentGeneration state generation to keep.
* @param locations state paths.
*/
public void cleanupOldFiles(final long currentGeneration, Path... locations) {
public void cleanupOldFiles(final long currentGeneration, Path[] locations) {
final String fileNameToKeep = getStateFileName(currentGeneration);
for (Path location : locations) {
logger.trace("cleanupOldFiles: cleaning up {}", location);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -346,7 +346,7 @@ public synchronized void writeDanglingIndicesInfo() {
return;
}
try {
IndexMetadata.FORMAT.writeAndCleanup(getMetadata(), nodeEnv.indexPath(index()));
IndexMetadata.FORMAT.writeAndCleanup(getMetadata(), nodeEnv.indexPaths(index()));
} catch (WriteStateException e) {
logger.warn(() -> new ParameterizedMessage("failed to write dangling indices state for index {}", index()), e);
}
Expand All @@ -358,7 +358,7 @@ public synchronized void deleteDanglingIndicesInfo() {
return;
}
try {
MetadataStateFormat.deleteMetaState(nodeEnv.indexPath(index()));
MetadataStateFormat.deleteMetaState(nodeEnv.indexPaths(index()));
} catch (IOException e) {
logger.warn(() -> new ParameterizedMessage("failed to delete dangling indices state for index {}", index()), e);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -940,7 +940,7 @@ private void deleteIndexStoreIfDeletionAllowed(final String reason, final Index
}
// this is a pure protection to make sure this index doesn't get re-imported as a dangling index.
// we should in the future rather write a tombstone rather than wiping the metadata.
MetadataStateFormat.deleteMetaState(nodeEnv.indexPath(index));
MetadataStateFormat.deleteMetaState(nodeEnv.indexPaths(index));
}
}

Expand Down Expand Up @@ -1029,7 +1029,7 @@ public IndexMetadata verifyIndexIsDeleted(final Index index, final ClusterState
if (clusterState.metadata().index(index) != null) {
throw new IllegalStateException("Cannot delete index [" + index + "], it is still part of the cluster state.");
}
if (nodeEnv.hasNodeFile() && Files.exists(nodeEnv.indexPath(index))) {
if (nodeEnv.hasNodeFile() && FileSystemUtils.exists(nodeEnv.indexPaths(index))) {
final IndexMetadata metadata;
try {
metadata = metaStateService.loadIndexState(index);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -102,9 +102,10 @@ public void testShardLock() throws Exception {
} catch (ShardLockObtainFailedException ex) {
// expected
}
Path path = env.indexPath(index);
Files.createDirectories(path.resolve("0"));
Files.createDirectories(path.resolve("1"));
for (Path path : env.indexPaths(index)) {
Files.createDirectories(path.resolve("0"));
Files.createDirectories(path.resolve("1"));
}
try {
env.lockAllForIndex(index, idxSettings, "3", randomIntBetween(0, 10));
fail("shard 0 is locked");
Expand Down Expand Up @@ -134,9 +135,10 @@ public void testAvailableIndexFolders() throws Exception {
Set<String> actualPaths = new HashSet<>();
for (int i = 0; i < numIndices; i++) {
Index index = new Index("foo" + i, "fooUUID" + i);
Path path = env.indexPath(index);
Files.createDirectories(path.resolve(MetadataStateFormat.STATE_DIR_NAME));
actualPaths.add(path.getFileName().toString());
for (Path path : env.indexPaths(index)) {
Files.createDirectories(path.resolve(MetadataStateFormat.STATE_DIR_NAME));
actualPaths.add(path.getFileName().toString());
}
}

assertThat(actualPaths, equalTo(env.availableIndexFolders()));
Expand All @@ -151,11 +153,12 @@ public void testAvailableIndexFoldersWithExclusions() throws Exception {
Set<String> actualPaths = new HashSet<>();
for (int i = 0; i < numIndices; i++) {
Index index = new Index("foo" + i, "fooUUID" + i);
Path path = env.indexPath(index);
Files.createDirectories(path.resolve(MetadataStateFormat.STATE_DIR_NAME));
actualPaths.add(path.getFileName().toString());
for (Path path : env.indexPaths(index)) {
Files.createDirectories(path.resolve(MetadataStateFormat.STATE_DIR_NAME));
actualPaths.add(path.getFileName().toString());
}
if (randomBoolean()) {
excludedPaths.add(env.indexPath(index).getFileName().toString());
excludedPaths.add(env.indexPaths(index)[0].getFileName().toString());
}
}

Expand All @@ -170,15 +173,17 @@ public void testResolveIndexFolders() throws Exception {
Map<String, List<Path>> actualIndexDataPaths = new HashMap<>();
for (int i = 0; i < numIndices; i++) {
Index index = new Index("foo" + i, "fooUUID" + i);
Path path = env.indexPath(index);
Files.createDirectories(path);
String fileName = path.getFileName().toString();
List<Path> paths = actualIndexDataPaths.get(fileName);
if (paths == null) {
paths = new ArrayList<>();
Path[] indexPaths = env.indexPaths(index);
for (Path path : indexPaths) {
Files.createDirectories(path);
String fileName = path.getFileName().toString();
List<Path> paths = actualIndexDataPaths.get(fileName);
if (paths == null) {
paths = new ArrayList<>();
}
paths.add(path);
actualIndexDataPaths.put(fileName, paths);
}
paths.add(path);
actualIndexDataPaths.put(fileName, paths);
}
for (Map.Entry<String, List<Path>> actualIndexDataPathEntry : actualIndexDataPaths.entrySet()) {
List<Path> actual = actualIndexDataPathEntry.getValue();
Expand All @@ -195,18 +200,20 @@ public void testDeleteSafe() throws Exception {
final ShardLock fooLock = env.shardLock(new ShardId(index, 0), "1");
assertEquals(new ShardId(index, 0), fooLock.getShardId());

Path path = env.indexPath(index);
Files.createDirectories(path.resolve("0"));
Files.createDirectories(path.resolve("1"));
for (Path path : env.indexPaths(index)) {
Files.createDirectories(path.resolve("0"));
Files.createDirectories(path.resolve("1"));
}

expectThrows(ShardLockObtainFailedException.class,
() -> env.deleteShardDirectorySafe(new ShardId(index, 0), idxSettings, shardPaths -> {
assert false : "should not be called " + shardPaths;
}));

path = env.indexPath(index);
assertTrue(Files.exists(path.resolve("0")));
assertTrue(Files.exists(path.resolve("1")));
for (Path path : env.indexPaths(index)) {
assertTrue(Files.exists(path.resolve("0")));
assertTrue(Files.exists(path.resolve("1")));
}

{
SetOnce<Path[]> listener = new SetOnce<>();
Expand All @@ -217,9 +224,10 @@ public void testDeleteSafe() throws Exception {
}
}

path = env.indexPath(index);
assertTrue(Files.exists(path.resolve("0")));
assertFalse(Files.exists(path.resolve("1")));
for (Path path : env.indexPaths(index)) {
assertTrue(Files.exists(path.resolve("0")));
assertFalse(Files.exists(path.resolve("1")));
}

expectThrows(ShardLockObtainFailedException.class,
() -> env.deleteIndexDirectorySafe(index, randomIntBetween(0, 10), idxSettings, indexPaths -> {
Expand All @@ -228,8 +236,9 @@ public void testDeleteSafe() throws Exception {

fooLock.close();

path = env.indexPath(index);
assertTrue(Files.exists(path));
for (Path path : env.indexPaths(index)) {
assertTrue(Files.exists(path));
}

final AtomicReference<Throwable> threadException = new AtomicReference<>();
final CountDownLatch latch = new CountDownLatch(1);
Expand Down Expand Up @@ -265,11 +274,12 @@ protected void doRun() throws Exception {

final SetOnce<Path[]> listener = new SetOnce<>();
env.deleteIndexDirectorySafe(index, 5000, idxSettings, listener::set);
assertThat(listener.get()[0], equalTo(env.indexPath(index)));
assertArrayEquals(env.indexPaths(index), listener.get());
assertNull(threadException.get());

path = env.indexPath(index);
assertFalse(Files.exists(path));
for (Path path : env.indexPaths(index)) {
assertFalse(Files.exists(path));
}
latch.await();
assertTrue("LockedShards: " + env.lockedShards(), env.lockedShards().isEmpty());
env.close();
Expand Down Expand Up @@ -351,7 +361,7 @@ public void testCustomDataPaths() throws Exception {
equalTo(dataPath.resolve("indices/" + index.getUUID() + "/0")));

assertThat("index paths uses the regular template",
env.indexPath(index), equalTo(dataPath.resolve("indices/" + index.getUUID())));
env.indexPaths(index)[0], equalTo(dataPath.resolve("indices/" + index.getUUID())));

assertThat(env.availableShardPaths(sid), equalTo(env.availableShardPaths(sid)));
assertThat(env.resolveCustomLocation("/tmp/foo", sid).toAbsolutePath(),
Expand All @@ -362,7 +372,7 @@ public void testCustomDataPaths() throws Exception {
equalTo(dataPath.resolve("indices/" + index.getUUID() + "/0")));

assertThat("index paths uses the regular template",
env.indexPath(index), equalTo(dataPath.resolve("indices/" + index.getUUID())));
env.indexPaths(index)[0], equalTo(dataPath.resolve("indices/" + index.getUUID())));

env.close();
}
Expand Down Expand Up @@ -405,8 +415,10 @@ public void testEnsureNoShardDataOrIndexMetadata() throws IOException {

Path indexPath;
try (NodeEnvironment env = newNodeEnvironment(settings)) {
indexPath = env.indexPath(index);
Files.createDirectories(indexPath.resolve(MetadataStateFormat.STATE_DIR_NAME));
for (Path path : env.indexPaths(index)) {
Files.createDirectories(path.resolve(MetadataStateFormat.STATE_DIR_NAME));
}
indexPath = env.indexPaths(index)[0];
}

verifyFailsOnMetadata(noDataNoMasterSettings, indexPath);
Expand All @@ -418,7 +430,9 @@ public void testEnsureNoShardDataOrIndexMetadata() throws IOException {

// test that we can create data=false env with only meta information. Also create shard data for following asserts
try (NodeEnvironment env = newNodeEnvironment(noDataSettings)) {
Files.createDirectories(env.indexPath(index).resolve(shardDataDirName));
for (Path path : env.indexPaths(index)) {
Files.createDirectories(path.resolve(shardDataDirName));
}
}

verifyFailsOnShardData(noDataSettings, indexPath, shardDataDirName);
Expand All @@ -434,7 +448,9 @@ public void testEnsureNoShardDataOrIndexMetadata() throws IOException {

// test that we can create data=true, master=true env. Also remove state dir to leave only shard data for following asserts
try (NodeEnvironment env = newNodeEnvironment(settings)) {
Files.delete(env.indexPath(index).resolve(MetadataStateFormat.STATE_DIR_NAME));
for (Path path : env.indexPaths(index)) {
Files.delete(path.resolve(MetadataStateFormat.STATE_DIR_NAME));
}
}

// assert that we fail on shard data even without the metadata dir.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -227,10 +227,11 @@ private void createIndexDataFiles(Settings settings, int shardCount, boolean wri
.build());
}
}
Path path = env.indexPath(INDEX);
for (int i = 0; i < shardCount; ++i) {
Files.createDirectories(path.resolve(Integer.toString(shardDataDirNumber)));
shardDataDirNumber += randomIntBetween(1,10);
for (Path path : env.indexPaths(INDEX)) {
for (int i = 0; i < shardCount; ++i) {
Files.createDirectories(path.resolve(Integer.toString(shardDataDirNumber)));
shardDataDirNumber += randomIntBetween(1,10);
}
}
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@
import org.elasticsearch.cluster.service.ClusterService;
import org.elasticsearch.common.Strings;
import org.elasticsearch.common.UUIDs;
import org.elasticsearch.common.io.FileSystemUtils;
import org.elasticsearch.common.settings.Setting;
import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.core.TimeValue;
Expand Down Expand Up @@ -62,7 +63,6 @@
import org.elasticsearch.test.hamcrest.RegexMatcher;

import java.io.IOException;
import java.nio.file.Files;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
Expand Down Expand Up @@ -351,7 +351,7 @@ public void testVerifyIfIndexContentDeleted() throws Exception {
.metadata(Metadata.builder(csWithIndex.metadata()).remove(index.getName()))
.build();
indicesService.verifyIndexIsDeleted(index, withoutIndex);
assertFalse("index files should be deleted", Files.exists(nodeEnv.indexPath(index)));
assertFalse("index files should be deleted", FileSystemUtils.exists(nodeEnv.indexPaths(index)));
}

public void testDanglingIndicesWithAliasConflict() throws Exception {
Expand Down