All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.elasticsearch.indices.recovery.plan.ShardSnapshot Maven / Gradle / Ivy

There is a newer version: 8.13.4
Show newest version
/*
 * Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
 * or more contributor license agreements. Licensed under the Elastic License
 * 2.0 and the Server Side Public License, v 1; you may not use this file except
 * in compliance with, at your election, the Elastic License 2.0 or the Server
 * Side Public License, v 1.
 */

package org.elasticsearch.indices.recovery.plan;

import org.elasticsearch.Version;
import org.elasticsearch.core.Nullable;
import org.elasticsearch.index.snapshots.blobstore.BlobStoreIndexShardSnapshot;
import org.elasticsearch.index.store.Store;
import org.elasticsearch.index.store.StoreFileMetadata;
import org.elasticsearch.repositories.IndexId;
import org.elasticsearch.repositories.ShardSnapshotInfo;

import java.util.List;
import java.util.Map;
import java.util.function.Function;
import java.util.stream.Collectors;

public class ShardSnapshot {
    private final ShardSnapshotInfo shardSnapshotInfo;
    // Segment file name -> file info
    private final Map snapshotFiles;
    private final Store.MetadataSnapshot metadataSnapshot;
    private final org.apache.lucene.util.Version commitLuceneVersion;

    public ShardSnapshot(
        ShardSnapshotInfo shardSnapshotInfo,
        List snapshotFiles,
        Map luceneCommitUserData,
        org.apache.lucene.util.Version commitLuceneVersion
    ) {
        this.shardSnapshotInfo = shardSnapshotInfo;
        this.snapshotFiles = snapshotFiles.stream()
            .collect(Collectors.toMap(snapshotFile -> snapshotFile.metadata().name(), Function.identity()));
        this.metadataSnapshot = convertToMetadataSnapshot(snapshotFiles, luceneCommitUserData);
        this.commitLuceneVersion = commitLuceneVersion;
    }

    public String getShardStateIdentifier() {
        return shardSnapshotInfo.getShardStateIdentifier();
    }

    public boolean isLogicallyEquivalent(@Nullable String shardStateIdentifier) {
        return shardStateIdentifier != null && shardStateIdentifier.equals(shardSnapshotInfo.getShardStateIdentifier());
    }

    public boolean hasDifferentPhysicalFiles(Store.MetadataSnapshot sourceSnapshot) {
        Store.RecoveryDiff recoveryDiff = metadataSnapshot.recoveryDiff(sourceSnapshot);
        return recoveryDiff.different.isEmpty() == false || recoveryDiff.missing.isEmpty() == false;
    }

    public String getRepository() {
        return shardSnapshotInfo.getRepository();
    }

    public Store.MetadataSnapshot getMetadataSnapshot() {
        return metadataSnapshot;
    }

    public IndexId getIndexId() {
        return shardSnapshotInfo.getIndexId();
    }

    public long getStartedAt() {
        return shardSnapshotInfo.getStartedAt();
    }

    public ShardSnapshotInfo getShardSnapshotInfo() {
        return shardSnapshotInfo;
    }

    @Nullable
    public Version getCommitVersion() {
        return metadataSnapshot.getCommitVersion();
    }

    public org.apache.lucene.util.Version getCommitLuceneVersion() {
        return commitLuceneVersion;
    }

    public List getSnapshotFilesMatching(List segmentFiles) {
        return segmentFiles.stream().map(storeFileMetadata -> snapshotFiles.get(storeFileMetadata.name())).toList();
    }

    public List getSnapshotFiles() {
        return List.copyOf(snapshotFiles.values());
    }

    static Store.MetadataSnapshot convertToMetadataSnapshot(
        List snapshotFiles,
        Map luceneCommitUserData
    ) {
        return new Store.MetadataSnapshot(
            snapshotFiles.stream()
                .map(BlobStoreIndexShardSnapshot.FileInfo::metadata)
                .collect(Collectors.toMap(StoreFileMetadata::name, Function.identity())),
            luceneCommitUserData,
            0
        );
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy