Interface Repository
- All Superinterfaces:
AutoCloseable
,Closeable
,LifecycleComponent
,org.elasticsearch.core.Releasable
- All Known Implementing Classes:
BlobStoreRepository
,FilterRepository
,FsRepository
,MeteredBlobStoreRepository
,UnknownTypeRepository
Implementations are responsible for reading and writing both metadata and shard data to and from a repository backend.
To perform a snapshot:
- Data nodes call
snapshotShard(org.elasticsearch.repositories.SnapshotShardContext)
for each shard - When all shard calls return master calls
finalizeSnapshot(org.elasticsearch.repositories.FinalizeSnapshotContext)
with possible list of failures
-
Nested Class Summary
Modifier and TypeInterfaceDescriptionstatic interface
An factory interface for constructing repositories. -
Method Summary
Modifier and TypeMethodDescriptionadaptUserMetadata
(Map<String, Object> userMetadata) Hook that allows a repository to filter the user supplied snapshot metadata inSnapshotsInProgress.Entry.userMetadata()
during snapshot initialization.static boolean
void
Block until all in-flight operations for this repository have completed.default boolean
canUpdateInPlace
(Settings updatedSettings, Set<String> ignoredSettings) Check if this instancesSettings
can be changed to the provided updated settings without recreating the repository.void
cloneShardSnapshot
(SnapshotId source, SnapshotId target, RepositoryShardId shardId, ShardGeneration shardGeneration, ActionListener<ShardSnapshotResult> listener) Clones a shard snapshot.void
deleteSnapshots
(Collection<SnapshotId> snapshotIds, long repositoryStateId, Version repositoryMetaVersion, ActionListener<RepositoryData> listener) Deletes snapshotsvoid
endVerification
(String verificationToken) Called at the end of repository verification process.void
executeConsistentStateUpdate
(Function<RepositoryData, ClusterStateUpdateTask> createUpdateTask, String source, Consumer<Exception> onFailure) Execute a cluster state update with a consistent view of the currentRepositoryData
.void
finalizeSnapshot
(FinalizeSnapshotContext finalizeSnapshotContext) Finalizes snapshotting processReturns metadata about this repository.void
getRepositoryData
(ActionListener<RepositoryData> listener) Returns aRepositoryData
to describe the data in the repository, including the snapshots and the indices across all snapshots found in the repository.long
Returns restore throttle time in nanosecondsgetShardSnapshotStatus
(SnapshotId snapshotId, IndexId indexId, ShardId shardId) Retrieve shard snapshot status for the stored snapshotgetSnapshotGlobalMetadata
(SnapshotId snapshotId) Returns global metadata associated with the snapshot.getSnapshotIndexMetaData
(RepositoryData repositoryData, SnapshotId snapshotId, IndexId index) Returns the index metadata associated with the snapshot.void
getSnapshotInfo
(GetSnapshotInfoContext context) Reads snapshot descriptions from the repository.default void
getSnapshotInfo
(SnapshotId snapshotId, ActionListener<SnapshotInfo> listener) Reads a single snapshot description from the repositorylong
Returns snapshot throttle time in nanosecondsboolean
Returns true if the repository supports only read operationsvoid
restoreShard
(Store store, SnapshotId snapshotId, IndexId indexId, ShardId snapshotShardId, RecoveryState recoveryState, ActionListener<Void> listener) Restores snapshot of the shard.void
snapshotShard
(SnapshotShardContext snapshotShardContext) Creates a snapshot of the shard referenced by the givenSnapshotShardContext
.Verifies repository on the master node and returns the verification token.default RepositoryStats
stats()
Returns stats on the repository usagevoid
updateState
(ClusterState state) Update the repository with the incoming cluster state.void
verify
(String verificationToken, DiscoveryNode localNode) Verifies repository settings on data node.Methods inherited from interface org.elasticsearch.common.component.LifecycleComponent
addLifecycleListener, lifecycleState, removeLifecycleListener, start, stop
Methods inherited from interface org.elasticsearch.core.Releasable
close
-
Method Details
-
getMetadata
RepositoryMetadata getMetadata()Returns metadata about this repository. -
getSnapshotInfo
Reads snapshot descriptions from the repository.- Parameters:
context
- get-snapshot-info-context
-
getSnapshotInfo
Reads a single snapshot description from the repository- Parameters:
snapshotId
- snapshot id to read description forlistener
- listener to resolve with snapshot description (is resolved on theThreadPool.Names.SNAPSHOT_META
pool)
-
getSnapshotGlobalMetadata
Returns global metadata associated with the snapshot.- Parameters:
snapshotId
- the snapshot id to load the global metadata from- Returns:
- the global metadata about the snapshot
-
getSnapshotIndexMetaData
IndexMetadata getSnapshotIndexMetaData(RepositoryData repositoryData, SnapshotId snapshotId, IndexId index) throws IOException Returns the index metadata associated with the snapshot.- Parameters:
repositoryData
- currentRepositoryData
snapshotId
- the snapshot id to load the index metadata fromindex
- theIndexId
to load the metadata from- Returns:
- the index metadata about the given index for the given snapshot
- Throws:
IOException
-
getRepositoryData
Returns aRepositoryData
to describe the data in the repository, including the snapshots and the indices across all snapshots found in the repository. Throws aRepositoryException
if there was an error in reading the data.- Parameters:
listener
- listener that may be resolved on different kinds of threads including transport and cluster state applier threads and therefore must fork to a new thread for executing any long running actions
-
finalizeSnapshot
Finalizes snapshotting processThis method is called on master after all shards are snapshotted.
- Parameters:
finalizeSnapshotContext
- finalization context
-
deleteSnapshots
void deleteSnapshots(Collection<SnapshotId> snapshotIds, long repositoryStateId, Version repositoryMetaVersion, ActionListener<RepositoryData> listener) Deletes snapshots- Parameters:
snapshotIds
- snapshot idsrepositoryStateId
- the unique id identifying the state of the repository when the snapshot deletion beganrepositoryMetaVersion
- version of the updated repository metadata to writelistener
- completion listener
-
getSnapshotThrottleTimeInNanos
long getSnapshotThrottleTimeInNanos()Returns snapshot throttle time in nanoseconds -
getRestoreThrottleTimeInNanos
long getRestoreThrottleTimeInNanos()Returns restore throttle time in nanoseconds -
stats
Returns stats on the repository usage -
startVerification
String startVerification()Verifies repository on the master node and returns the verification token.If the verification token is not null, it's passed to all data nodes for verification. If it's null - no additional verification is required
- Returns:
- verification token that should be passed to all Index Shard Repositories for additional verification or null
-
endVerification
Called at the end of repository verification process.This method should perform all necessary cleanup of the temporary files created in the repository
- Parameters:
verificationToken
- verification request generated bystartVerification()
command
-
verify
Verifies repository settings on data node.- Parameters:
verificationToken
- value returned bystartVerification()
localNode
- the local node information, for inclusion in verification errors
-
isReadOnly
boolean isReadOnly()Returns true if the repository supports only read operations- Returns:
- true if the repository is read/only
-
snapshotShard
Creates a snapshot of the shard referenced by the givenSnapshotShardContext
.As snapshot process progresses, implementation of this method should update
IndexShardSnapshotStatus
object returned bySnapshotShardContext.status()
and check itsIndexShardSnapshotStatus.isAborted()
to see if the snapshot process should be aborted.- Parameters:
snapshotShardContext
- snapshot shard context that must be completed viaSnapshotShardContext.onResponse(org.elasticsearch.repositories.ShardSnapshotResult)
orActionListener.Delegating.onFailure(java.lang.Exception)
-
restoreShard
void restoreShard(Store store, SnapshotId snapshotId, IndexId indexId, ShardId snapshotShardId, RecoveryState recoveryState, ActionListener<Void> listener) Restores snapshot of the shard.The index can be renamed on restore, hence different
shardId
andsnapshotShardId
are supplied.- Parameters:
store
- the store to restore the index intosnapshotId
- snapshot idindexId
- id of the index in the repository from which the restore is occurringsnapshotShardId
- shard id (in the snapshot)recoveryState
- recovery statelistener
- listener to invoke once done
-
getShardSnapshotStatus
IndexShardSnapshotStatus getShardSnapshotStatus(SnapshotId snapshotId, IndexId indexId, ShardId shardId) Retrieve shard snapshot status for the stored snapshot- Parameters:
snapshotId
- snapshot idindexId
- the snapshotted index id for the shard to get status forshardId
- shard id- Returns:
- snapshot status
-
canUpdateInPlace
Check if this instancesSettings
can be changed to the provided updated settings without recreating the repository.- Parameters:
updatedSettings
- new repository settingsignoredSettings
- setting names to ignore even if changed- Returns:
- true if the repository can be updated in place
-
updateState
Update the repository with the incoming cluster state. This method is invoked fromRepositoriesService.applyClusterState(org.elasticsearch.cluster.ClusterChangedEvent)
and thus the same semantics as withClusterStateApplier.applyClusterState(org.elasticsearch.cluster.ClusterChangedEvent)
apply for theClusterState
that is passed here.- Parameters:
state
- new cluster state
-
executeConsistentStateUpdate
void executeConsistentStateUpdate(Function<RepositoryData, ClusterStateUpdateTask> createUpdateTask, String source, Consumer<Exception> onFailure) Execute a cluster state update with a consistent view of the currentRepositoryData
. TheClusterState
passed to the task generated throughcreateUpdateTask
is guaranteed to point at the same state for this repository as the did the state at the time theRepositoryData
was loaded. This allows for operations on the repository that need a consistent view of both the cluster state and the repository contents at one point in time like for example, checking if a snapshot is in the repository before adding the delete operation for it to the cluster state.- Parameters:
createUpdateTask
- function to supply cluster state update tasksource
- the source of the cluster state update taskonFailure
- error handler invoked on failure to get a consistent view of the currentRepositoryData
-
cloneShardSnapshot
void cloneShardSnapshot(SnapshotId source, SnapshotId target, RepositoryShardId shardId, @Nullable ShardGeneration shardGeneration, ActionListener<ShardSnapshotResult> listener) Clones a shard snapshot.- Parameters:
source
- source snapshottarget
- target snapshotshardId
- shard idshardGeneration
- shard generation in repolistener
- listener to complete with new shard generation once clone has completed
-
adaptUserMetadata
Hook that allows a repository to filter the user supplied snapshot metadata inSnapshotsInProgress.Entry.userMetadata()
during snapshot initialization. -
awaitIdle
void awaitIdle()Block until all in-flight operations for this repository have completed. Must only be called after this instance has been closed by a call to stopReleasable.close()
. Waiting for ongoing operations should be implemented here instead of inLifecycleComponent.stop()
orReleasable.close()
hooks of this interface as these are expected to be called on the cluster state applier thread (which must not block) if a repository is removed from the cluster. This method is intended to be called on node shutdown instead as a means to ensure no repository operations are leaked. -
assertSnapshotMetaThread
static boolean assertSnapshotMetaThread()
-