|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object java.util.logging.Handler java.util.logging.StreamHandler java.util.logging.FileHandler
Simple file logging Handler.
The FileHandler can either write to a specified file, or it can write to a rotating set of files.
For a rotating set of files, as each file reaches a given size limit, it is closed, rotated out, and a new file opened. Successively older files are named by adding "0", "1", "2", etc into the base filename.
By default buffering is enabled in the IO libraries but each log record is flushed out when it is complete.
By default the XMLFormatter class is used for formatting.
Configuration: By default each FileHandler is initialized using the following LogManager configuration properties. If properties are not defined (or have invalid values) then the specified default values are used.
A pattern consists of a string that includes the following special components that will be replaced at runtime:
Thus for example a pattern of "%t/java%g.log" with a count of 2 would typically cause log files to be written on Solaris to /var/tmp/java0.log and /var/tmp/java1.log whereas on Windows 95 they would be typically written to to C:\TEMP\java0.log and C:\TEMP\java1.log
Generation numbers follow the sequence 0, 1, 2, etc.
Normally the "%u" unique field is set to 0. However, if the FileHandler tries to open the filename and finds the file is currently in use by another process it will increment the unique number field and try again. This will be repeated until FileHandler finds a file name that is not currently in use. If there is a conflict and no "%u" field has been specified, it will be added at the end of the filename after a dot. (This will be after any automatically added generation number.)
Thus if three processes were all trying to log to fred%u.%g.txt then they might end up using fred0.0.txt, fred1.0.txt, fred2.0.txt as the first file in their rotating sequences.
Note that the use of unique ids to avoid conflicts is only guaranteed to work reliably when using a local disk file system.
Nested Class Summary | |
private static class |
FileHandler.InitializationErrorManager
|
private class |
FileHandler.MeteredStream
|
Field Summary | |
private boolean |
append
|
private int |
count
|
private File[] |
files
|
private int |
limit
|
private String |
lockFileName
|
private static HashMap |
locks
|
private FileOutputStream |
lockStream
|
private static int |
MAX_LOCKS
|
private FileHandler.MeteredStream |
meter
|
private String |
pattern
|
Fields inherited from class java.util.logging.StreamHandler |
|
Fields inherited from class java.util.logging.Handler |
sealed |
Constructor Summary | |
FileHandler()
Construct a default FileHandler. |
|
FileHandler(String pattern)
Initialize a FileHandler to write to the given filename. |
|
FileHandler(String pattern,
boolean append)
Initialize a FileHandler to write to the given filename, with optional append. |
|
FileHandler(String pattern,
int limit,
int count)
Initialize a FileHandler to write to a set of files. |
|
FileHandler(String pattern,
int limit,
int count,
boolean append)
Initialize a FileHandler to write to a set of files with optional append. |
Method Summary | |
void |
close()
Close all the files. |
private void |
configure()
|
private File |
generate(String pattern,
int generation,
int unique)
|
private static boolean |
isSetUID()
|
private void |
open(File fname,
boolean append)
|
private void |
openFiles()
|
void |
publish(LogRecord record)
Format and publish a LogRecord. |
private void |
rotate()
|
Methods inherited from class java.util.logging.StreamHandler |
flush, isLoggable, setEncoding, setOutputStream |
Methods inherited from class java.util.logging.Handler |
checkAccess, getEncoding, getErrorManager, getFilter, getFormatter, getLevel, reportError, setErrorManager, setFilter, setFormatter, setLevel |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
private FileHandler.MeteredStream meter
private boolean append
private int limit
private int count
private String pattern
private String lockFileName
private FileOutputStream lockStream
private File[] files
private static final int MAX_LOCKS
private static HashMap locks
Constructor Detail |
public FileHandler() throws IOException, SecurityException
IOException
- if there are IO problems opening the files.
SecurityException
- if a security manager exists and if
the caller does not have LoggingPermission("control")).public FileHandler(String pattern) throws IOException, SecurityException
The FileHandler is configured based on LogManager properties (or their default values) except that the given pattern argument is used as the filename pattern, the file limit is set to no limit, and the file count is set to one.
There is no limit on the amount of data that may be written, so use this with care.
pattern
- the name of the output file
IOException
- if there are IO problems opening the files.
SecurityException
- if a security manager exists and if
the caller does not have LoggingPermission("control").public FileHandler(String pattern, boolean append) throws IOException, SecurityException
The FileHandler is configured based on LogManager properties (or their default values) except that the given pattern argument is used as the filename pattern, the file limit is set to no limit, the file count is set to one, and the append mode is set to the given append argument.
There is no limit on the amount of data that may be written, so use this with care.
pattern
- the name of the output fileappend
- specifies append mode
IOException
- if there are IO problems opening the files.
SecurityException
- if a security manager exists and if
the caller does not have LoggingPermission("control").public FileHandler(String pattern, int limit, int count) throws IOException, SecurityException
The FileHandler is configured based on LogManager properties (or their default values) except that the given pattern argument is used as the filename pattern, the file limit is set to the limit argument, and the file count is set to the given count argument.
The count must be at least 1.
pattern
- the pattern for naming the output filelimit
- the maximum number of bytes to write to any one filecount
- the number of files to use
IOException
- if there are IO problems opening the files.
SecurityException
- if a security manager exists and if
the caller does not have LoggingPermission("control").
IllegalArgumentException
- if limit < 0, or count < 1.public FileHandler(String pattern, int limit, int count, boolean append) throws IOException, SecurityException
The FileHandler is configured based on LogManager properties (or their default values) except that the given pattern argument is used as the filename pattern, the file limit is set to the limit argument, and the file count is set to the given count argument, and the append mode is set to the given append argument.
The count must be at least 1.
pattern
- the pattern for naming the output filelimit
- the maximum number of bytes to write to any one filecount
- the number of files to useappend
- specifies append mode
IOException
- if there are IO problems opening the files.
SecurityException
- if a security manager exists and if
the caller does not have LoggingPermission("control").
IllegalArgumentException
- if limit < 0, or count < 1.Method Detail |
private void open(File fname, boolean append) throws IOException
IOException
private void configure()
private void openFiles() throws IOException
IOException
private File generate(String pattern, int generation, int unique) throws IOException
IOException
private void rotate()
public void publish(LogRecord record)
publish
in class StreamHandler
record
- description of the log eventpublic void close() throws SecurityException
close
in class StreamHandler
SecurityException
- if a security manager exists and if
the caller does not have LoggingPermission("control").private static boolean isSetUID()
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |