public class ReliableLog extends Object
The secondary storage strategy is to record values in files using a representation of the caller's choosing. Two sorts of files are kept: snapshots and logs. At any instant, one snapshot is current. The log consists of a sequence of updates that have occurred since the current snapshot was taken. The current stable state is the value of the snapshot, as modified by the sequence of updates in the log. From time to time, the client of a ReliableLog instructs the package to make a new snapshot and clear the log. A ReliableLog arranges disk writes such that updates are stable (as long as the changes are force-written to disk) and atomic: no update is lost, and each update either is recorded completely in the log or not at all. Making a new snapshot is also atomic.
Normal use for maintaining the recoverable store is as follows: The client maintains the relevant data structure in virtual memory. As updates happen to the structure, the client informs the ReliableLog (call it "log") by calling log.update. Periodically, the client calls log.snapshot to provide the current complete contents of the data. On restart, the client calls log.recover to obtain the latest snapshot and the following sequences of updates; the client applies the updates to the snapshot to obtain the state that existed before the crash.
LogHandler
Modifier and Type | Field and Description |
---|---|
private File |
dir |
private int |
format |
private static int |
FORMAT_PADDED |
private static int |
FORMAT_UNPADDED |
private LogHandler |
handler |
private byte[] |
intBuf |
private static long |
intBytes |
private RandomAccessFile |
log |
private long |
logBytes |
private FileDescriptor |
logFD |
private static String |
logfilePrefix |
private String |
logName |
private static int |
MAGIC |
private long |
snapshotBytes |
private static String |
snapshotPrefix |
private int |
version |
private static String |
versionFile |
private byte[] |
zeroBuf |
Constructor and Description |
---|
ReliableLog(String dirPath,
LogHandler handler)
Creates a ReliableLog to handle snapshots and logging in a
stable storage directory, and sets up to recover any existing data
from the stable storage directory.
|
Modifier and Type | Method and Description |
---|---|
void |
close()
Closes the stable storage directory in an orderly manner.
|
private void |
deleteFile(String name)
Deletes a file.
|
private void |
deleteLogFile(int ver)
Removes the incremental update log file.
|
void |
deletePersistentStore()
Closes the incremental update log file, removes all ReliableLog-related
files from the stable storage directory, and deletes the directory.
|
private void |
deleteSnapshot(int ver)
Removes the snapshot file.
|
private String |
fName(String name)
Generates a filename prepended with the stable storage directory path.
|
long |
logSize()
Returns the current size of the incremental update log file in bytes;
|
private void |
openLogFile()
Opens the incremental update log file in read/write mode.
|
void |
recover()
Retrieves the contents of the snapshot file by calling the client
supplied recover callback and then applies the incremental updates
by calling the readUpdate callback for each logged updated.
|
void |
snapshot()
Records the client-defined current snapshot by invoking the client
supplied snapshot callback, and then empties the log of incremental
updates.
|
long |
snapshotSize()
Returns the size of the current snapshot file in bytes;
|
void |
update(Object value)
Records this update in the log file and forces the update to disk.
|
void |
update(Object value,
boolean forceToDisk)
Records this update in the log file and optionally forces the update
to disk.
|
private String |
versionName(String name)
Generates a version filename prepended with the stable storage
directory path with the current version number as a suffix.
|
private String |
versionName(String prefix,
int ver)
Generates a version filename prepended with the stable storage
directory path with the given version number as a suffix.
|
private void |
writeInt(DataOutput out,
int val)
Write an int value in single write operation.
|
private void |
writeVersionFile()
Writes the current version number to the version file.
|
private static final String snapshotPrefix
private static final String logfilePrefix
private static final String versionFile
private static final int MAGIC
private static final int FORMAT_UNPADDED
private static final int FORMAT_PADDED
private static final long intBytes
private final File dir
private int version
private int format
private String logName
private RandomAccessFile log
private FileDescriptor logFD
private long snapshotBytes
private long logBytes
private final LogHandler handler
private final byte[] intBuf
private final byte[] zeroBuf
public ReliableLog(String dirPath, LogHandler handler) throws IOException
dirPath
- path to the stable storage directoryhandler
- the handler for log callbacksLogException
- if the directory cannot be created or
the current version in the directory is corruptedIOException
- if any other I/O error occurspublic void recover() throws IOException
LogException
- if recovery fails due to serious log corruption,
or if an exception is thrown by the recover or readUpdate callbacksIOException
- if an other I/O error occurspublic void update(Object value) throws IOException
value
- the object representing the updateLogException
- if an exception is thrown by the writeUpdate
callback, or forcing the update to disk failsIOException
- if any other I/O error occurspublic void update(Object value, boolean forceToDisk) throws IOException
value
- the object representing the updateforceToDisk
- true if the update should be forced to disk, false
if the updates should be bufferedLogException
- if an exception is thrown by the writeUpdate
callback, or forcing the update to disk failsIOException
- if any other I/O error occursprivate void writeInt(DataOutput out, int val) throws IOException
out
- output streamval
- int valueIOException
- if any other I/O error occurspublic void snapshot() throws IOException
LogException
- if the snapshot callback throws an exceptionIOException
- if any other I/O error occurspublic void close() throws IOException
IOException
- if an I/O error occurspublic void deletePersistentStore()
public long snapshotSize()
public long logSize()
private String fName(String name)
name
- the name of the file (sans directory path)private String versionName(String name)
name
- version filename prefixprivate String versionName(String prefix, int ver)
prefix
- filename prefixver
- version numberprivate void deleteFile(String name) throws LogException
name
- the name of the file (complete path)LogException
- if file cannot be deletedprivate void deleteSnapshot(int ver) throws LogException
ver
- the version to removeLogException
- if file cannot be deletedprivate void deleteLogFile(int ver) throws LogException
ver
- the version to removeLogException
- if file cannot be deletedprivate void openLogFile() throws IOException
IOException
- if an I/O error occursprivate void writeVersionFile() throws IOException
IOException
- if an I/O error occursCopyright 2007-2013, multiple authors.
Licensed under the Apache License, Version 2.0, see the NOTICE file for attributions.