Package org.apache.lucene.replicator.nrt
Class CopyJob
java.lang.Object
org.apache.lucene.replicator.nrt.CopyJob
- All Implemented Interfaces:
- Comparable<CopyJob>
Handles copying one set of files, e.g. all files for a new NRT point, or files for pre-copying a
 merged segment. This notifies the caller via OnceDone when the job finishes or failed.
- WARNING: This API is experimental and might change in incompatible ways in the next release.
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic interfaceCallback invoked by CopyJob once all files have (finally) finished copying
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected Stringprotected CopyOneFileprotected final ReplicaNodeprotected Throwableprotected final Map<String, FileMetaData> final booleanTrue for an NRT sync, false for pre-copying a newly merged segmentfinal CopyJob.OnceDonefinal longfinal Stringfinal longprotected final List<Map.Entry<String, FileMetaData>> protected longprotected long
- 
Constructor SummaryConstructorsModifierConstructorDescriptionprotectedCopyJob(String reason, Map<String, FileMetaData> files, ReplicaNode dest, boolean highPriority, CopyJob.OnceDone onceDone) 
- 
Method SummaryModifier and TypeMethodDescriptionvoidabstract booleanReturn true if this job is trying to copy any of the same files as the other jobabstract voidfinish()Renames all copied (tmp) files to their true file namesabstract CopyStateabstract booleanReturns all file names referenced in this copy jobReturns only those file names (a subset ofgetFileNames()) that need to be copiedabstract longprotected abstract CopyOneFilenewCopyOneFile(CopyOneFile current) abstract voidUse current thread (blocking) to do all copying and then return once done, or throw exception on failureabstract voidstart()Begin copying filesvoidtransferAndCancel(CopyJob prevJob) Transfers whatever tmp files were already copied in this previous job and cancels the previous jobMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface java.lang.ComparablecompareTo
- 
Field Details- 
dest
- 
files
- 
ordpublic final long ord
- 
highPrioritypublic final boolean highPriorityTrue for an NRT sync, false for pre-copying a newly merged segment
- 
onceDone
- 
startNSpublic final long startNS
- 
reason
- 
toCopy
- 
totBytesprotected long totBytes
- 
totBytesCopiedprotected long totBytesCopied
- 
current
- 
exc
- 
cancelReason
- 
copiedFiles
 
- 
- 
Constructor Details- 
CopyJobprotected CopyJob(String reason, Map<String, FileMetaData> files, ReplicaNode dest, boolean highPriority, CopyJob.OnceDone onceDone) throws IOException- Throws:
- IOException
 
 
- 
- 
Method Details- 
transferAndCancelTransfers whatever tmp files were already copied in this previous job and cancels the previous job- Throws:
- IOException
 
- 
newCopyOneFile
- 
startBegin copying files- Throws:
- IOException
 
- 
runBlockingUse current thread (blocking) to do all copying and then return once done, or throw exception on failure- Throws:
- Exception
 
- 
cancel- Throws:
- IOException
 
- 
conflictsReturn true if this job is trying to copy any of the same files as the other job
- 
finishRenames all copied (tmp) files to their true file names- Throws:
- IOException
 
- 
getFailedpublic abstract boolean getFailed()
- 
getFileNamesToCopyReturns only those file names (a subset ofgetFileNames()) that need to be copied
- 
getFileNamesReturns all file names referenced in this copy job
- 
getCopyState
- 
getTotalBytesCopiedpublic abstract long getTotalBytesCopied()
 
-