Class DefaultLuceneIndexSnapshotManager
- java.lang.Object
- 
- com.atlassian.confluence.internal.index.lucene.snapshot.DefaultLuceneIndexSnapshotManager
 
- 
- All Implemented Interfaces:
- LuceneIndexSnapshotManager
 
 public class DefaultLuceneIndexSnapshotManager extends Object implements LuceneIndexSnapshotManager Manage all Lucene index snapshots. In DC, all index snapshots are stored undershared-home/index-snapshots. There is a limit of how many snapshots are retained at any time for an index. The default is 3. Exceeded snapshots are regularly purged byLuceneIndexSnapshotCleaner.- Since:
- 7.6.0
 
- 
- 
Constructor SummaryConstructors Constructor Description DefaultLuceneIndexSnapshotManager(com.atlassian.plugin.PluginAccessor pluginAccessor, BootstrapManager bootstrapManager, com.atlassian.dc.filestore.api.compat.FilesystemPath sharedHome, JournalStateStore journalStateStore)DefaultLuceneIndexSnapshotManager(com.atlassian.plugin.PluginAccessor pluginAccessor, BootstrapManager bootstrapManager, com.atlassian.dc.filestore.api.compat.FilesystemPath sharedHome, JournalStateStore journalStateStore, Function<Path,Optional<Long>> indexVersionReader)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description LuceneIndexSnapshotcreate(JournalIdentifier journalIdentifier)Create a new Lucene index snapshot for given journal (index)voiddelete(LuceneIndexSnapshot snapshot)Delete an index snapshot from file system.Optional<LuceneIndexSnapshot>find(JournalIdentifier journalIdentifier, long journalEntryId)Find a specific index snapshot corresponding to a journal entry ID.Optional<LuceneIndexSnapshot>find(JournalIdentifier journalIdentifier, long journalEntryId, long timeoutMs)Find a specific index snapshot corresponding to a journal entry ID.List<LuceneIndexSnapshot>findForJournal(JournalIdentifier journalIdentifier)Optional<Path>getFile(LuceneIndexSnapshot snapshot)Obtain location of an index snapshot.voidrestore(LuceneIndexSnapshot snapshot)Restore a Lucene snapshot for given journal (index) to the current node
 
- 
- 
- 
Constructor Detail- 
DefaultLuceneIndexSnapshotManagerpublic DefaultLuceneIndexSnapshotManager(com.atlassian.plugin.PluginAccessor pluginAccessor, BootstrapManager bootstrapManager, com.atlassian.dc.filestore.api.compat.FilesystemPath sharedHome, JournalStateStore journalStateStore)
 - 
DefaultLuceneIndexSnapshotManagerpublic DefaultLuceneIndexSnapshotManager(com.atlassian.plugin.PluginAccessor pluginAccessor, BootstrapManager bootstrapManager, com.atlassian.dc.filestore.api.compat.FilesystemPath sharedHome, JournalStateStore journalStateStore, Function<Path,Optional<Long>> indexVersionReader)
 
- 
 - 
Method Detail- 
createpublic LuceneIndexSnapshot create(JournalIdentifier journalIdentifier) Description copied from interface:LuceneIndexSnapshotManagerCreate a new Lucene index snapshot for given journal (index)- Specified by:
- createin interface- LuceneIndexSnapshotManager
- Parameters:
- journalIdentifier- Identifier of a journal of which a snapshot will be created
- Returns:
- newly created snapshot, its content can be accessed by LuceneIndexSnapshotManager.getFile(LuceneIndexSnapshot)
 
 - 
restorepublic void restore(LuceneIndexSnapshot snapshot) Description copied from interface:LuceneIndexSnapshotManagerRestore a Lucene snapshot for given journal (index) to the current node- Specified by:
- restorein interface- LuceneIndexSnapshotManager
- Parameters:
- snapshot- snapshot to restore
 
 - 
findForJournalpublic List<LuceneIndexSnapshot> findForJournal(JournalIdentifier journalIdentifier) - Specified by:
- findForJournalin interface- LuceneIndexSnapshotManager
- Returns:
- all snapshots created for given journal (index) in chronological order (desc)
 
 - 
findpublic Optional<LuceneIndexSnapshot> find(JournalIdentifier journalIdentifier, long journalEntryId) Description copied from interface:LuceneIndexSnapshotManagerFind a specific index snapshot corresponding to a journal entry ID. This method returns immediately. Note: In certain network filesystem it may take a while after a snapshot file is created by a node until it is visible to other nodes. If you want to find a newly created snapshot and wait until it becomes visible, useLuceneIndexSnapshotManager.find(JournalIdentifier, long, long)- Specified by:
- findin interface- LuceneIndexSnapshotManager
- Parameters:
- journalIdentifier- Identifier of a journal of which a snapshot will be created
- journalEntryId- place in journal when snapshot was created
 
 - 
findpublic Optional<LuceneIndexSnapshot> find(JournalIdentifier journalIdentifier, long journalEntryId, long timeoutMs) throws InterruptedException Description copied from interface:LuceneIndexSnapshotManagerFind a specific index snapshot corresponding to a journal entry ID. If it cannot be found immediately then this method will wait until it becomes visible or certain time has passed.- Specified by:
- findin interface- LuceneIndexSnapshotManager
- Parameters:
- journalIdentifier- Identifier of a journal of which a snapshot will be created
- journalEntryId- place in journal when snapshot was created
- timeoutMs- max time to wait until the snapshot file is available
- Returns:
- Location of the zipped snapshot in file system if found within waitTimeMsor empty
- Throws:
- InterruptedException
 
 - 
deletepublic void delete(LuceneIndexSnapshot snapshot) throws IOException Description copied from interface:LuceneIndexSnapshotManagerDelete an index snapshot from file system. Do nothing if the snapshot doesn't exist- Specified by:
- deletein interface- LuceneIndexSnapshotManager
- Parameters:
- snapshot- The snapshot to be deleted
- Throws:
- IOException- If there is error deleting the snapshot file
 
 - 
getFilepublic Optional<Path> getFile(LuceneIndexSnapshot snapshot) Description copied from interface:LuceneIndexSnapshotManagerObtain location of an index snapshot.- Specified by:
- getFilein interface- LuceneIndexSnapshotManager
- Parameters:
- snapshot- Index snapshot to be accessed
- Returns:
- Location of the zipped snapshot in file system
 
 
- 
 
-