java.util.logging
Class FileHandler

java.lang.Object sample code for java.lang.Object definition code for java.lang.Object 
  extended by java.util.logging.Handler sample code for java.util.logging.Handler definition code for java.util.logging.Handler 
      extended by java.util.logging.StreamHandler sample code for java.util.logging.StreamHandler definition code for java.util.logging.StreamHandler 
          extended by java.util.logging.FileHandler

public class FileHandler
extends StreamHandler sample code for java.util.logging.StreamHandler definition code for java.util.logging.StreamHandler

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:

If no "%g" field has been specified and the file count is greater than one, then the generation number will be added to the end of the generated filename, after a dot.

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 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.

Since:
1.4

Constructor Summary
FileHandler sample code for java.util.logging.FileHandler.FileHandler() definition code for java.util.logging.FileHandler.FileHandler() ()
          Construct a default FileHandler.
FileHandler sample code for java.util.logging.FileHandler.FileHandler(java.lang.String) definition code for java.util.logging.FileHandler.FileHandler(java.lang.String) (String sample code for java.lang.String definition code for java.lang.String  pattern)
          Initialize a FileHandler to write to the given filename.
FileHandler sample code for java.util.logging.FileHandler.FileHandler(java.lang.String, boolean) definition code for java.util.logging.FileHandler.FileHandler(java.lang.String, boolean) (String sample code for java.lang.String definition code for java.lang.String  pattern, boolean append)
          Initialize a FileHandler to write to the given filename, with optional append.
FileHandler sample code for java.util.logging.FileHandler.FileHandler(java.lang.String, int, int) definition code for java.util.logging.FileHandler.FileHandler(java.lang.String, int, int) (String sample code for java.lang.String definition code for java.lang.String  pattern, int limit, int count)
          Initialize a FileHandler to write to a set of files.
FileHandler sample code for java.util.logging.FileHandler.FileHandler(java.lang.String, int, int, boolean) definition code for java.util.logging.FileHandler.FileHandler(java.lang.String, int, int, boolean) (String sample code for java.lang.String definition code for java.lang.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 sample code for java.util.logging.FileHandler.close() definition code for java.util.logging.FileHandler.close() ()
          Close all the files.
 void publish sample code for java.util.logging.FileHandler.publish(java.util.logging.LogRecord) definition code for java.util.logging.FileHandler.publish(java.util.logging.LogRecord) (LogRecord sample code for java.util.logging.LogRecord definition code for java.util.logging.LogRecord  record)
          Format and publish a LogRecord.
 
Methods inherited from class java.util.logging.StreamHandler sample code for java.util.logging.StreamHandler definition code for java.util.logging.StreamHandler
flush sample code for java.util.logging.StreamHandler.flush() definition code for java.util.logging.StreamHandler.flush() , isLoggable sample code for java.util.logging.StreamHandler.isLoggable(java.util.logging.LogRecord) definition code for java.util.logging.StreamHandler.isLoggable(java.util.logging.LogRecord) , setEncoding sample code for java.util.logging.StreamHandler.setEncoding(java.lang.String) definition code for java.util.logging.StreamHandler.setEncoding(java.lang.String) , setOutputStream sample code for java.util.logging.StreamHandler.setOutputStream(java.io.OutputStream) definition code for java.util.logging.StreamHandler.setOutputStream(java.io.OutputStream)
 
Methods inherited from class java.util.logging.Handler sample code for java.util.logging.Handler definition code for java.util.logging.Handler
getEncoding sample code for java.util.logging.Handler.getEncoding() definition code for java.util.logging.Handler.getEncoding() , getErrorManager sample code for java.util.logging.Handler.getErrorManager() definition code for java.util.logging.Handler.getErrorManager() , getFilter sample code for java.util.logging.Handler.getFilter() definition code for java.util.logging.Handler.getFilter() , getFormatter sample code for java.util.logging.Handler.getFormatter() definition code for java.util.logging.Handler.getFormatter() , getLevel sample code for java.util.logging.Handler.getLevel() definition code for java.util.logging.Handler.getLevel() , reportError sample code for java.util.logging.Handler.reportError(java.lang.String, java.lang.Exception, int) definition code for java.util.logging.Handler.reportError(java.lang.String, java.lang.Exception, int) , setErrorManager sample code for java.util.logging.Handler.setErrorManager(java.util.logging.ErrorManager) definition code for java.util.logging.Handler.setErrorManager(java.util.logging.ErrorManager) , setFilter sample code for java.util.logging.Handler.setFilter(java.util.logging.Filter) definition code for java.util.logging.Handler.setFilter(java.util.logging.Filter) , setFormatter sample code for java.util.logging.Handler.setFormatter(java.util.logging.Formatter) definition code for java.util.logging.Handler.setFormatter(java.util.logging.Formatter) , setLevel sample code for java.util.logging.Handler.setLevel(java.util.logging.Level) definition code for java.util.logging.Handler.setLevel(java.util.logging.Level)
 
Methods inherited from class java.lang.Object sample code for java.lang.Object definition code for java.lang.Object
clone sample code for java.lang.Object.clone() definition code for java.lang.Object.clone() , equals sample code for java.lang.Object.equals(java.lang.Object) definition code for java.lang.Object.equals(java.lang.Object) , finalize sample code for java.lang.Object.finalize() definition code for java.lang.Object.finalize() , getClass sample code for java.lang.Object.getClass() definition code for java.lang.Object.getClass() , hashCode sample code for java.lang.Object.hashCode() definition code for java.lang.Object.hashCode() , notify sample code for java.lang.Object.notify() definition code for java.lang.Object.notify() , notifyAll sample code for java.lang.Object.notifyAll() definition code for java.lang.Object.notifyAll() , toString sample code for java.lang.Object.toString() definition code for java.lang.Object.toString() , wait sample code for java.lang.Object.wait() definition code for java.lang.Object.wait() , wait sample code for java.lang.Object.wait(long) definition code for java.lang.Object.wait(long) , wait sample code for java.lang.Object.wait(long, int) definition code for java.lang.Object.wait(long, int)
 

Constructor Detail

FileHandler sample code for java.util.logging.FileHandler() definition code for java.util.logging.FileHandler()

public FileHandler()
            throws IOException sample code for java.io.IOException definition code for java.io.IOException ,
                   SecurityException sample code for java.lang.SecurityException definition code for java.lang.SecurityException 
Construct a default FileHandler. This will be configured entirely from LogManager properties (or their default values).

Throws:
IOException sample code for java.io.IOException definition code for java.io.IOException - if there are IO problems opening the files.
SecurityException sample code for java.lang.SecurityException definition code for java.lang.SecurityException - if a security manager exists and if the caller does not have LoggingPermission("control")).
NullPointerException sample code for java.lang.NullPointerException definition code for java.lang.NullPointerException - if pattern property is an empty String.

FileHandler sample code for java.util.logging.FileHandler(java.lang.String) definition code for java.util.logging.FileHandler(java.lang.String)

public FileHandler(String sample code for java.lang.String definition code for java.lang.String  pattern)
            throws IOException sample code for java.io.IOException definition code for java.io.IOException ,
                   SecurityException sample code for java.lang.SecurityException definition code for java.lang.SecurityException 
Initialize a FileHandler to write to the given filename.

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.

Parameters:
pattern - the name of the output file
Throws:
IOException sample code for java.io.IOException definition code for java.io.IOException - if there are IO problems opening the files.
SecurityException sample code for java.lang.SecurityException definition code for java.lang.SecurityException - if a security manager exists and if the caller does not have LoggingPermission("control").
IllegalArgumentException sample code for java.lang.IllegalArgumentException definition code for java.lang.IllegalArgumentException - if pattern is an empty string

FileHandler sample code for java.util.logging.FileHandler(java.lang.String, boolean) definition code for java.util.logging.FileHandler(java.lang.String, boolean)

public FileHandler(String sample code for java.lang.String definition code for java.lang.String  pattern,
                   boolean append)
            throws IOException sample code for java.io.IOException definition code for java.io.IOException ,
                   SecurityException sample code for java.lang.SecurityException definition code for java.lang.SecurityException 
Initialize a FileHandler to write to the given filename, with optional append.

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.

Parameters:
pattern - the name of the output file
append - specifies append mode
Throws:
IOException sample code for java.io.IOException definition code for java.io.IOException - if there are IO problems opening the files.
SecurityException sample code for java.lang.SecurityException definition code for java.lang.SecurityException - if a security manager exists and if the caller does not have LoggingPermission("control").
IllegalArgumentException sample code for java.lang.IllegalArgumentException definition code for java.lang.IllegalArgumentException - if pattern is an empty string

FileHandler sample code for java.util.logging.FileHandler(java.lang.String, int, int) definition code for java.util.logging.FileHandler(java.lang.String, int, int)

public FileHandler(String sample code for java.lang.String definition code for java.lang.String  pattern,
                   int limit,
                   int count)
            throws IOException sample code for java.io.IOException definition code for java.io.IOException ,
                   SecurityException sample code for java.lang.SecurityException definition code for java.lang.SecurityException 
Initialize a FileHandler to write to a set of files. When (approximately) the given limit has been written to one file, another file will be opened. The output will cycle through a set of count files.

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.

Parameters:
pattern - the pattern for naming the output file
limit - the maximum number of bytes to write to any one file
count - the number of files to use
Throws:
IOException sample code for java.io.IOException definition code for java.io.IOException - if there are IO problems opening the files.
SecurityException sample code for java.lang.SecurityException definition code for java.lang.SecurityException - if a security manager exists and if the caller does not have LoggingPermission("control").
IllegalArgumentException sample code for java.lang.IllegalArgumentException definition code for java.lang.IllegalArgumentException - if limit < 0, or count < 1.
IllegalArgumentException sample code for java.lang.IllegalArgumentException definition code for java.lang.IllegalArgumentException - if pattern is an empty string

FileHandler sample code for java.util.logging.FileHandler(java.lang.String, int, int, boolean) definition code for java.util.logging.FileHandler(java.lang.String, int, int, boolean)

public FileHandler(String sample code for java.lang.String definition code for java.lang.String  pattern,
                   int limit,
                   int count,
                   boolean append)
            throws IOException sample code for java.io.IOException definition code for java.io.IOException ,
                   SecurityException sample code for java.lang.SecurityException definition code for java.lang.SecurityException 
Initialize a FileHandler to write to a set of files with optional append. When (approximately) the given limit has been written to one file, another file will be opened. The output will cycle through a set of count files.

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.

Parameters:
pattern - the pattern for naming the output file
limit - the maximum number of bytes to write to any one file
count - the number of files to use
append - specifies append mode
Throws:
IOException sample code for java.io.IOException definition code for java.io.IOException - if there are IO problems opening the files.
SecurityException sample code for java.lang.SecurityException definition code for java.lang.SecurityException - if a security manager exists and if the caller does not have LoggingPermission("control").
IllegalArgumentException sample code for java.lang.IllegalArgumentException definition code for java.lang.IllegalArgumentException - if limit < 0, or count < 1.
IllegalArgumentException sample code for java.lang.IllegalArgumentException definition code for java.lang.IllegalArgumentException - if pattern is an empty string
Method Detail

publish sample code for java.util.logging.FileHandler.publish(java.util.logging.LogRecord) definition code for java.util.logging.FileHandler.publish(java.util.logging.LogRecord)

public void publish(LogRecord sample code for java.util.logging.LogRecord definition code for java.util.logging.LogRecord  record)
Format and publish a LogRecord.

Overrides:
publish sample code for java.util.logging.StreamHandler.publish(java.util.logging.LogRecord) definition code for java.util.logging.StreamHandler.publish(java.util.logging.LogRecord) in class StreamHandler sample code for java.util.logging.StreamHandler definition code for java.util.logging.StreamHandler
Parameters:
record - description of the log event. A null record is silently ignored and is not published

close sample code for java.util.logging.FileHandler.close() definition code for java.util.logging.FileHandler.close()

public void close()
           throws SecurityException sample code for java.lang.SecurityException definition code for java.lang.SecurityException 
Close all the files.

Overrides:
close sample code for java.util.logging.StreamHandler.close() definition code for java.util.logging.StreamHandler.close() in class StreamHandler sample code for java.util.logging.StreamHandler definition code for java.util.logging.StreamHandler
Throws:
SecurityException sample code for java.lang.SecurityException definition code for java.lang.SecurityException - if a security manager exists and if the caller does not have LoggingPermission("control").