Loggers main offering is a level that can be set, anything at or above that level gets output, anything below gets silently ignored. So you can keep your debug messages in your code and only turn them on when needed.
The logging levels are:
Level | Description |
SEVERE | The highest value; intended for extremely important messages (e.g. fatal program errors). |
WARNING | Intended for warning messages. |
INFO | Informational runtime messages. |
CONFIG | Informational messages about configuration settings/setup. |
FINE | Used for greater detail, when debugging/diagnosing problems. |
FINER | Even greater detail. |
FINEST | The lowest value; greatest detail. |
A quick start example would look something like this:
package com.wownow;
import java.io.IOException;
import java.util.logging.FileHandler;
import java.util.logging.Level;
import java.util.logging.Logger;
public class MyLoggingTest {
public static void main(String[] args) throws IOException {
Level logLevel = Level.FINE;
FileHandler fh = new FileHandler("MyLogFile.xml");
Logger logger = Logger.getLogger("MyLogger");
logger.setLevel(logLevel);
logger.addHandler(fh);
logger.severe("My Severe Message");
logger.warning("My Warning Message");
logger.info("My Info Message");
logger.config("My Config Message");
logger.fine("My Fine Message");
logger.finer("My Finer Message");
logger.finest("My Finest Message");
fh.close();
}
}
import java.io.IOException;
import java.util.logging.FileHandler;
import java.util.logging.Level;
import java.util.logging.Logger;
public class MyLoggingTest {
public static void main(String[] args) throws IOException {
Level logLevel = Level.FINE;
FileHandler fh = new FileHandler("MyLogFile.xml");
Logger logger = Logger.getLogger("MyLogger");
logger.setLevel(logLevel);
logger.addHandler(fh);
logger.severe("My Severe Message");
logger.warning("My Warning Message");
logger.info("My Info Message");
logger.config("My Config Message");
logger.fine("My Fine Message");
logger.finer("My Finer Message");
logger.finest("My Finest Message");
fh.close();
}
}
In this example we:
- first set the logLevel to "FINE",
- then create our log file "MyLogFile.xml", by default Logger outputs to file in xml format.
- We then create the logger object, set the level and add the file handler.
- Next we output a message for each logging level. Only the messages above the set level, "FINE", will be output. The logger also outputs to console but only to "INFO" level by default.
- We then close the file handler.
The xml output looks something like:
<?xml version="1.0" encoding="windows-1252" standalone="no"?>
<!DOCTYPE log SYSTEM "logger.dtd">
<log>
<record>
<date>2009-06-09T12:23:56</date>
<millis>1244546636747</millis>
<sequence>0</sequence>
<logger>MyLogger</logger>
<level>SEVERE</level>
<class>com.rrf.mypackage.MyLoggingTest</class>
<method>main</method>
<thread>10</thread>
<message>My Severe Message</message>
</record>
<record>
<date>2009-06-09T12:23:56</date>
<millis>1244546636763</millis>
<sequence>1</sequence>
<logger>MyLogger</logger>
<level>WARNING</level>
<class>com.rrf.mypackage.MyLoggingTest</class>
<method>main</method>
<thread>10</thread>
<message>My Warning Message</message>
</record>
...
</log>
<!DOCTYPE log SYSTEM "logger.dtd">
<log>
<record>
<date>2009-06-09T12:23:56</date>
<millis>1244546636747</millis>
<sequence>0</sequence>
<logger>MyLogger</logger>
<level>SEVERE</level>
<class>com.rrf.mypackage.MyLoggingTest</class>
<method>main</method>
<thread>10</thread>
<message>My Severe Message</message>
</record>
<record>
<date>2009-06-09T12:23:56</date>
<millis>1244546636763</millis>
<sequence>1</sequence>
<logger>MyLogger</logger>
<level>WARNING</level>
<class>com.rrf.mypackage.MyLoggingTest</class>
<method>main</method>
<thread>10</thread>
<message>My Warning Message</message>
</record>
...
</log>
There are also two special levels Level.ALL and Level.OFF
See Console,Text and XML Logger Output to see how to output different levels and formats to different destinations.
There is much more to Logger, see here.
Logged.
No comments:
Post a Comment