Package com.tangosol.io.journal
Class AbstractJournalRM.JournalFile
java.lang.Object
com.tangosol.io.journal.AbstractJournalRM.JournalFile
- All Implemented Interfaces:
Disposable
,AutoCloseable
- Direct Known Subclasses:
AbstractJournalRM.CollectorDaemon.InvokeGCJournalFile
,FlashJournalRM.JournalFile
,RamJournalRM.JournalFile
- Enclosing class:
AbstractJournalRM
A JournalFile object is created for each file used to store the journal
contents. It is created in an initial "append" mode -- which may be
interrupted from time to time by a "congested" mode if writes are
falling too far behind, it then transitions to a "full" mode, and
once enough of its storage has been released it transitions to an
"evacuating" mode, which (once evacuated) becomes "garbage" and (upon
deletion) is "discarded".
-
Field Summary
FieldsModifier and TypeFieldDescriptionprotected final Condition
A condition associated with a synchronization lock above that is used to wait for notification and to notify waiting threads.protected final Lock
The lock that should be used to control concurrent access to this Journal File.protected final AtomicLong
Amount of data that has been released.protected final AtomicLong
Amount of data that has been written.protected boolean
Set to true when the JournalFile is notified that it is full and its contents have been fully written.protected AbstractJournalRM.JournalFile
The JournalFile that "comes after" this JournalFile in the journal.protected final AtomicLong
Current state of the JournalFile and the appending offset within the file.protected final int
The file index.static final long
State: File is being appended to.static final long
State: File is appending, but there is congestion forcing a wait by all appending threads.static final long
State: File has been discarded.static final long
State: Remaining entries in the file are being evacuated.static final long
State: File is full and appends are no longer occurring.static final long
State: File is garbage and can safely be discarded.static final long
The bits of them_lStateOffset
that are used for the current state of the file (one of the STATE_* constants).static final long
State: File is reserved by the CollectorDaemon. -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionprotected boolean
compareAndSetOffset
(long lPrevValue, long lOffset) Specify the new offset value of this JournalFile.protected boolean
compareAndSetState
(long lPrevValue, long lState) Specify the current state of this JournalFile unless the state isSTATE_RESERVED
as it is a special case and should be set viasetReserved(boolean)
.abstract void
dispose()
Invoked when all resources owned by the implementer can safely be released.abstract long
Enqueue a Binary value to be written to this file, returning a ticket, or return 0L if this file is full and the append has to occur to a new file.void
evacuate()
Called by the CollectorDaemon to evacuate all remaining data from the JournalFile.long
Determine the number of bytes written.protected String
Format the object attributes into a String for inclusion in the String returned from thetoString()
method.int
Determine the file id (0-511) for this JournalFile.Determine the JournalFile for the file in the journal that follows the file represented by this JournalFile.long
Determine the current append offset (or length) of this JournalFile.protected long
getOffset
(long lStateOffset) Determine the current append offset (or length) from the provided long.long
Determine the number of bytes that have been released from this JournalFile.long
getState()
Determine the current state of this JournalFile.protected long
getState
(long lState) Determine the state of the provided (potentially) unmaskedlState
.boolean
Return whether the JournalFile can be appended to.boolean
Return whether the JournalFile has been reserved thus can not be used by clients.void
Called by the CollectorDaemon the first time that the JournalFile is encountered in its FULL state and its data has all been written.abstract Binary
read
(long lTicket) Read the Binary associated with the specified ticket from the journal file.void
release
(int cbValue) Release the specified number of bytes from this journal file.void
setNextJournalFile
(AbstractJournalRM.JournalFile jrnlfileNext) Once this file has been filled, it gets a reference to the file that follows it.protected void
setReserved
(boolean fReserved) Specify whether the current JournalFile is reserved.protected void
setState
(long lState) Specify the current state of this JournalFile.toString()
void
touch()
This method is called periodically by the collector daemon to indicate that the file is still being used.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
Methods inherited from interface com.oracle.coherence.common.base.Disposable
close
-
Field Details
-
STATE_APPENDING
public static final long STATE_APPENDINGState: File is being appended to.- See Also:
-
STATE_CONGESTION
public static final long STATE_CONGESTIONState: File is appending, but there is congestion forcing a wait by all appending threads.- See Also:
-
STATE_FULL
public static final long STATE_FULLState: File is full and appends are no longer occurring.- See Also:
-
STATE_EVACUATING
public static final long STATE_EVACUATINGState: Remaining entries in the file are being evacuated.- See Also:
-
STATE_GARBAGE
public static final long STATE_GARBAGEState: File is garbage and can safely be discarded.- See Also:
-
STATE_DISCARDED
public static final long STATE_DISCARDEDState: File has been discarded.- See Also:
-
STATE_RESERVED
public static final long STATE_RESERVEDState: File is reserved by the CollectorDaemon. This state differs from the others as it may exist in combination with the other states thus is a marker.- See Also:
-
STATE_MASK
public static final long STATE_MASKThe bits of them_lStateOffset
that are used for the current state of the file (one of the STATE_* constants).- See Also:
-
m_nFile
protected final int m_nFileThe file index. Immutable field. -
m_lStateOffset
Current state of the JournalFile and the appending offset within the file. These two values are maintained in a single "long" value so that the file can be appended to and transitioned from state to state in an atomic manner, i.e. when the file gets close to being full, it can be transitioned from the "appending" state in the same manner as an append itself is done (which simply updates the offset). -
m_cbWritten
Amount of data that has been written. -
m_cbReleased
Amount of data that has been released. -
m_jrnlfileNext
The JournalFile that "comes after" this JournalFile in the journal. -
m_fNotifiedFull
protected boolean m_fNotifiedFullSet to true when the JournalFile is notified that it is full and its contents have been fully written. -
f_journalFileLock
The lock that should be used to control concurrent access to this Journal File. -
f_journalFileCondition
A condition associated with a synchronization lock above that is used to wait for notification and to notify waiting threads.
-
-
Constructor Details
-
JournalFile
public JournalFile(int nFile) Construct a Journal File.- Parameters:
nFile
- the file number in the range 0-511 (inclusive)
-
-
Method Details
-
enqueue
Enqueue a Binary value to be written to this file, returning a ticket, or return 0L if this file is full and the append has to occur to a new file.- Parameters:
bin
- the value to append to the journal file- Returns:
- a ticket if the Binary has successfully been enqueued, or 0L if the file is full
-
read
Read the Binary associated with the specified ticket from the journal file.- Parameters:
lTicket
- a ticket previously returned fromenqueue(com.tangosol.util.Binary)
- Returns:
- the Binary value that is associated with the ticket
-
release
public void release(int cbValue) Release the specified number of bytes from this journal file.- Parameters:
cbValue
- the number of bytes that are being released
-
getFileId
public int getFileId()Determine the file id (0-511) for this JournalFile.- Returns:
- the file id for this JournalFile
-
getState
public long getState()Determine the current state of this JournalFile.- Returns:
- the one of the STATE_* constants
-
getOffset
public long getOffset()Determine the current append offset (or length) of this JournalFile.- Returns:
- the current append offset
-
getBytesWritten
public long getBytesWritten()Determine the number of bytes written.- Returns:
- the number of bytes that have been reported to have been written
-
getReleased
public long getReleased()Determine the number of bytes that have been released from this JournalFile.- Returns:
- the number of bytes that have been released from this file
-
isAppending
public boolean isAppending()Return whether the JournalFile can be appended to.- Returns:
- whether the JournalFile can be appended to
-
isReserved
public boolean isReserved()Return whether the JournalFile has been reserved thus can not be used by clients.- Returns:
- whether the JournalFile has been reserved
-
touch
public void touch()This method is called periodically by the collector daemon to indicate that the file is still being used. -
getNextJournalFile
Determine the JournalFile for the file in the journal that follows the file represented by this JournalFile.- Returns:
- the next file in the journal, or null if it has not yet been set
-
setNextJournalFile
Once this file has been filled, it gets a reference to the file that follows it.- Parameters:
jrnlfileNext
- the next file in the journal
-
getDescription
Format the object attributes into a String for inclusion in the String returned from thetoString()
method.- Returns:
- a comma-delimited String listing the attributes of this object in the form "attribute=value"
-
notifyWriteCompleted
public void notifyWriteCompleted()Called by the CollectorDaemon the first time that the JournalFile is encountered in its FULL state and its data has all been written. -
evacuate
public void evacuate()Called by the CollectorDaemon to evacuate all remaining data from the JournalFile. -
setReserved
protected void setReserved(boolean fReserved) Specify whether the current JournalFile is reserved.- Parameters:
fReserved
- whether the JournalFile is reserved
-
dispose
public abstract void dispose()Invoked when all resources owned by the implementer can safely be released.Once disposed of the object should no longer be considered to be usable.
Note the Disposable interface is compatible with try-with-resources which will automatically invoke this method.
- Specified by:
dispose
in interfaceDisposable
-
toString
-
getState
protected long getState(long lState) Determine the state of the provided (potentially) unmaskedlState
.- Parameters:
lState
- the journal file state- Returns:
- the state only value
-
setState
protected void setState(long lState) Specify the current state of this JournalFile.- Parameters:
lState
- one of the STATE_* constants
-
compareAndSetState
protected boolean compareAndSetState(long lPrevValue, long lState) Specify the current state of this JournalFile unless the state isSTATE_RESERVED
as it is a special case and should be set viasetReserved(boolean)
.- Parameters:
lPrevValue
- the expected state valuelState
- one of the STATE_* constants, except STATE_RESERVED- Returns:
- true if the value was successfully cas'd
-
compareAndSetOffset
protected boolean compareAndSetOffset(long lPrevValue, long lOffset) Specify the new offset value of this JournalFile.- Parameters:
lPrevValue
- the expected state valuelOffset
- the new offset value- Returns:
- true if the value was successfully cas'd
-
getOffset
protected long getOffset(long lStateOffset) Determine the current append offset (or length) from the provided long.- Parameters:
lStateOffset
- the long value holding both the state and offset- Returns:
- the current append offset
-