public class FileManager
extends java.lang.Object
| Modifier and Type | Class and Description |
|---|---|
static class |
FileManager.FileMode |
(package private) class |
FileManager.LogEndFileDescriptor
The LogEndFileDescriptor is used to write and fsync the end of the log.
|
| Modifier and Type | Field and Description |
|---|---|
static java.lang.String |
BAD_SUFFIX |
static java.lang.String |
DEL_SUFFIX |
(package private) static java.lang.String[] |
DEL_SUFFIXES |
(package private) static boolean |
IO_EXCEPTION_TESTING_ON_READ |
(package private) static boolean |
IO_EXCEPTION_TESTING_ON_WRITE |
static java.lang.String |
JE_SUFFIX |
(package private) static java.lang.String[] |
JE_SUFFIXES |
(package private) long |
lastFileNumberTouched |
(package private) long |
lastFileTouchedOffset |
static long |
N_BAD_WRITES |
(package private) int |
nFileOpens |
(package private) long |
nRandomReadBytes |
(package private) long |
nRandomReads |
(package private) long |
nRandomWriteBytes |
(package private) long |
nRandomWrites |
(package private) long |
nSequentialReadBytes |
(package private) long |
nSequentialReads |
(package private) long |
nSequentialWriteBytes |
(package private) long |
nSequentialWrites |
static boolean |
RUNRECOVERY_EXCEPTION_TESTING |
static long |
STOP_ON_WRITE_COUNT |
static boolean |
THROW_ON_WRITE |
(package private) static boolean |
THROW_RRE_FOR_UNIT_TESTS |
boolean |
VERIFY_CHECKSUMS |
static long |
WRITE_COUNT |
| Constructor and Description |
|---|
FileManager(EnvironmentImpl envImpl,
java.io.File dbEnvHome,
boolean readOnly)
Set up the file cache and initialize the file manager to point to the
beginning of the log.
|
| Modifier and Type | Method and Description |
|---|---|
(package private) boolean |
bumpLsn(long size)
Increase the current log position by "size" bytes.
|
boolean |
checkEnvHomePermissions(boolean readOnly)
Ensure that if the environment home dir is on readonly media or in a
readonly directory that the environment has been opened for readonly
access.
|
void |
clear()
Close all file handles and empty the cache.
|
void |
close()
Clear the file lock.
|
void |
deleteFile(long fileNum)
Delete log file NNNNNNNN.
|
boolean |
filesExist() |
static int |
firstLogEntryOffset() |
(package private) void |
forceNewLogFile()
Set the flag that causes a new file to be written before the next write.
|
java.lang.Long[] |
getAllFileNumbers()
Get all JE file numbers.
|
(package private) java.util.Set<java.lang.Long> |
getCacheKeys() |
long |
getCurrentFileNum()
Returns the highest (current) file number.
|
(package private) FileHandle |
getFileHandle(long fileNum)
Return a read only file handle that corresponds the this file number.
|
(package private) long |
getFileHeaderPrevOffset(long fileNum) |
int |
getFileLogVersion(long fileNum)
Returns the log version for the given file.
|
static java.lang.String |
getFileName(long fileNum,
java.lang.String suffix) |
java.lang.Long |
getFirstFileNum()
public for cleaner.
|
java.lang.Long |
getFollowingFileNum(long currentFileNum,
boolean forward)
Get the next file number before/after currentFileNum.
|
java.lang.String |
getFullFileName(long fileNum,
java.lang.String suffix) |
(package private) java.lang.String[] |
getFullFileNames(long fileNum) |
java.lang.Long |
getLastFileNum() |
long |
getLastUsedLsn()
Return the last allocated LSN in the log.
|
long |
getNextLsn()
Return the next available LSN in the log.
|
long |
getNFSyncRequests() |
long |
getNFSyncs() |
long |
getNFSyncTimeouts() |
java.lang.Long |
getNumFromName(java.lang.String fileName)
Get the file number from a file name.
|
(package private) long |
getPrevEntryOffset() |
boolean |
getReadOnly() |
(package private) void |
groupSync()
Flush a file using the group sync mechanism, trying to amortize off
other syncs.
|
boolean |
isFileValid(long fileNum)
For assertions that check whether a file is valid or has been deleted
via log cleaning.
|
static java.lang.String[] |
listFiles(java.io.File envDirFile,
java.lang.String[] suffixes)
Find JE files, flavor for unit test support.
|
java.lang.String[] |
listFiles(long minFileNumber,
long maxFileNumber)
Find .jdb files which are >= the minimimum file number and
<= the maximum file number.
|
java.lang.String[] |
listFiles(java.lang.String[] suffixes)
Find JE files.
|
(package private) void |
loadStats(StatsConfig config,
EnvironmentStats stats) |
boolean |
lockEnvironment(boolean readOnly,
boolean exclusive)
Lock the environment.
|
(package private) void |
readFromFile(java.io.RandomAccessFile file,
java.nio.ByteBuffer readBuffer,
long offset,
long fileNo)
Read a buffer from a file at a given offset, using NIO if so configured.
|
void |
releaseExclusiveLock() |
static void |
removeFiles(java.io.File envFile)
Remove files from the environment home directory.
|
void |
renameFile(long fileNum,
java.lang.String newSuffix)
Rename this file to NNNNNNNN.suffix.
|
(package private) void |
restoreLastPosition() |
(package private) void |
saveLastPosition() |
void |
setIncludeDeletedFiles(boolean includeDeletedFiles) |
void |
setLastPosition(long nextAvailableLsn,
long lastUsedLsn,
long prevOffset)
Set the file manager's "end of log".
|
void |
setSyncAtFileEnd(boolean sync)
May be used to disable sync at file end to speed unit tests.
|
(package private) void |
syncLogEnd()
FSync the end of the log.
|
(package private) void |
syncLogEndAndFinishFile()
Sync the end of the log, close off this log file.
|
void |
truncateLog(long fileNum,
long offset)
Truncate a log at this position.
|
(package private) void |
writeLogBuffer(LogBuffer fullBuffer)
Write out a log buffer to the file.
|
static boolean IO_EXCEPTION_TESTING_ON_WRITE
static boolean IO_EXCEPTION_TESTING_ON_READ
static boolean THROW_RRE_FOR_UNIT_TESTS
public static long WRITE_COUNT
public static long STOP_ON_WRITE_COUNT
public static long N_BAD_WRITES
public static boolean THROW_ON_WRITE
public static final java.lang.String JE_SUFFIX
public static final java.lang.String DEL_SUFFIX
public static final java.lang.String BAD_SUFFIX
static final java.lang.String[] DEL_SUFFIXES
static final java.lang.String[] JE_SUFFIXES
public boolean VERIFY_CHECKSUMS
long lastFileNumberTouched
long lastFileTouchedOffset
long nRandomReads
long nRandomWrites
long nSequentialReads
long nSequentialWrites
long nRandomReadBytes
long nRandomWriteBytes
long nSequentialReadBytes
long nSequentialWriteBytes
int nFileOpens
public static final boolean RUNRECOVERY_EXCEPTION_TESTING
public FileManager(EnvironmentImpl envImpl, java.io.File dbEnvHome, boolean readOnly) throws DatabaseException
configManager - dbEnvHome - environment home directoryDatabaseExceptionpublic void setLastPosition(long nextAvailableLsn,
long lastUsedLsn,
long prevOffset)
nextAvailableLsn - LSN to be used for the next log entrylastUsedLsn - last LSN to have a valid entry, may be nullprevOffset - value to use for the prevOffset of the next entry.
If the beginning of the file, this is 0.void saveLastPosition()
void restoreLastPosition()
public void setSyncAtFileEnd(boolean sync)
public java.lang.Long getFirstFileNum()
public boolean getReadOnly()
public java.lang.Long getLastFileNum()
public long getCurrentFileNum()
public boolean isFileValid(long fileNum)
public void setIncludeDeletedFiles(boolean includeDeletedFiles)
public java.lang.Long[] getAllFileNumbers()
public java.lang.Long getFollowingFileNum(long currentFileNum,
boolean forward)
currentFileNum - the file we're at right now. Note that
it may not exist, if it's been cleaned and renamed.forward - if true, we want the next larger file, if false
we want the previous filepublic boolean filesExist()
public java.lang.Long getNumFromName(java.lang.String fileName)
the - file namepublic java.lang.String[] listFiles(java.lang.String[] suffixes)
suffix - which type of file we're looking forpublic java.lang.String[] listFiles(long minFileNumber,
long maxFileNumber)
public static java.lang.String[] listFiles(java.io.File envDirFile,
java.lang.String[] suffixes)
suffix - which type of file we're looking forjava.lang.String[] getFullFileNames(long fileNum)
public static void removeFiles(java.io.File envFile)
throws java.io.IOException
envFile - environment directoryjava.io.IOExceptionpublic java.lang.String getFullFileName(long fileNum,
java.lang.String suffix)
public static java.lang.String getFileName(long fileNum,
java.lang.String suffix)
public void renameFile(long fileNum,
java.lang.String newSuffix)
throws DatabaseException,
java.io.IOException
fileNum - the file we want to movenewSuffix - the new file suffixDatabaseExceptionjava.io.IOExceptionpublic void deleteFile(long fileNum)
throws DatabaseException,
java.io.IOException
fileNum - the file we want to moveDatabaseExceptionjava.io.IOExceptionpublic int getFileLogVersion(long fileNum)
throws LogException,
DatabaseException
LogExceptionDatabaseExceptionFileHandle getFileHandle(long fileNum) throws LogException, DatabaseException
fileNum - which fileLogExceptionDatabaseExceptionlong getFileHeaderPrevOffset(long fileNum)
throws java.io.IOException,
DatabaseException
java.io.IOExceptionDatabaseExceptionlong getPrevEntryOffset()
boolean bumpLsn(long size)
size - is an unsigned intvoid writeLogBuffer(LogBuffer fullBuffer) throws DatabaseException
fullBuffer - buffer to writeDatabaseExceptionvoid readFromFile(java.io.RandomAccessFile file,
java.nio.ByteBuffer readBuffer,
long offset,
long fileNo)
throws DatabaseException,
java.io.IOException
DatabaseExceptionjava.io.IOExceptionvoid syncLogEnd()
throws DatabaseException
DatabaseExceptionvoid syncLogEndAndFinishFile()
throws DatabaseException,
java.io.IOException
DatabaseExceptionjava.io.IOExceptionvoid groupSync()
throws DatabaseException
DatabaseExceptionpublic void clear()
throws java.io.IOException,
DatabaseException
java.io.IOExceptionDatabaseExceptionpublic void close()
throws java.io.IOException,
DatabaseException
java.io.IOExceptionDatabaseExceptionpublic boolean lockEnvironment(boolean readOnly,
boolean exclusive)
throws DatabaseException
DatabaseExceptionpublic void releaseExclusiveLock()
throws DatabaseException
DatabaseExceptionpublic boolean checkEnvHomePermissions(boolean readOnly)
throws DatabaseException
DatabaseExceptionpublic void truncateLog(long fileNum,
long offset)
throws java.io.IOException,
DatabaseException
This method forces a new log file to be written next, if the last file (the file truncated to) has an old version in its header. This ensures that when the log is opened by an old version of JE, a version incompatibility will be detected. [#11243]
java.io.IOExceptionDatabaseExceptionvoid forceNewLogFile()
public static int firstLogEntryOffset()
public long getNextLsn()
public long getLastUsedLsn()
public long getNFSyncs()
public long getNFSyncRequests()
public long getNFSyncTimeouts()
void loadStats(StatsConfig config, EnvironmentStats stats) throws DatabaseException
DatabaseExceptionjava.util.Set<java.lang.Long> getCacheKeys()
Copyright (c) 2004,2008 Oracle. All rights reserved.