The Log4j 1.x bridge
Perhaps the simplest way to convert to using Log4j 2 is to replace the log4j 1.x jar file with
Log4j 2's log4j-1.2-api jar. However, to use this successfully applications must meet the
following requirements:
- They must not access methods and classes internal to the Log4j 1.x implementation such
as Appenders, LoggerRepository or Logger's callAppenders method.
- They must not programmatically configure Log4j.
- They must not be configuring by calling DomConfigurator or the PropertiesConfigurator.
Converting to the Log4j 2 API
For the most part, converting from the Log4j 1.x API to Log4j 2.0 should be fairly simple. Many
of the log statements will require no modification. However, where necessary the following changes must be
made.
- Calls to Logger.getLogger must be modified to LogManager.getLogger.
- Calls to Logger.getRootLogger or LogManager.getRootLogger must be replaced woth
LogManager.getLogger("").
- Calls to LogManager.getLogger that accept a LoggerFactory must remove the LoggerFactory and
use one of Log4j 2's other extension mechanisms.
- Calls to logger.setLevel or similar methods are not supported in the API. Applications
should remove these. Equivalent functionality is provided in the Log4j 2 implementation
classes but may leave the application susceptible to changes in Log4j 2 internals.
- The Log4j 2 API methods accept String messages instead of Objects. Applications that
wish to log Objects should either wrap the Object in an ObjectMessage or create a
custom Message for the Object.
- Where appropriate, applications should convert to use parameterized messages instead of
String concatenation.
Configuration
Although the Log4j 2 configuration syntax is different than that of Log4j 1.x, most, if not all, of
the same functionality is available. Below are the example configurations for Log4j 1.x and their
counterparts in Log4j 2.
Sample 1 - Simple configuration using a Console Appender
Log4j 1.x XML configuration
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration PUBLIC "-//APACHE//DTD LOG4J 1.2//EN" "log4j.dtd">
<log4j:configuration xmlns:log4j='http://jakarta.apache.org/log4j/'>
<appender name="STDOUT" class="org.apache.log4j.ConsoleAppender">
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d %-5p [%t] %C{2} (%F:%L) - %m%n"/>
</layout>
</appender>
<category name="org.apache.log4j.xml">
<priority value="info" />
</category>
<root>
<priority value ="debug" />
<appender-ref ref="STDOUT" />
</root>
</log4j:configuration>
Log4j 2 XML configuration
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<appenders>
<Console name="STDOUT" target="SYSTEM_OUT">
<PatternLayout pattern="%d %-5p [%t] %C{2} (%F:%L) - %m%n"/>
</Console>
</appenders>
<loggers>
<logger name="org.apache.log4j.xml" level="info"/>
<root level="debug">
<appender-ref ref="STDOUT"/>
</root>
</loggers>
</configuration>
Sample 2 - Simple configuration using a File Appender
Log4j 1.x XML configuration
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration PUBLIC "-//APACHE//DTD LOG4J 1.2//EN" "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
<appender name="A1" class="org.apache.log4j.FileAppender">
<param name="File" value="A1.log" />
<param name="Append" value="false" />
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%t %-5p %c{2} - %m%n"/>
</layout>
</appender>
<appender name="STDOUT" class="org.apache.log4j.ConsoleAppender">
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d %-5p [%t] %C{2} (%F:%L) - %m%n"/>
</layout>
</appender>
<category name="org.apache.log4j.xml">
<priority value="debug" />
<appender-ref ref="A1" />
</category>
<root>
<priority value ="debug" />
<appender-ref ref="STDOUT" />
</root>
</log4j:configuration>
Log4j 2 XML configuration
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<appenders>
<File name="A1" fileName="A1.log" append="false">
<PatternLayout pattern="%t %-5p %c{2} - %m%n"/>
</File>
<Console name="STDOUT" target="SYSTEM_OUT">
<PatternLayout pattern="%d %-5p [%t] %C{2} (%F:%L) - %m%n"/>
</Console>
</appenders>
<loggers>
<logger name="org.apache.log4j.xml" level="debug">
<appender-ref ref="A1"/>
</logger>
<root level="debug">
<appender-ref ref="STDOUT"/>
</root>
</loggers>
</configuration>
Sample 3 - SocketAppender
Log4j 1.x XML configuration. This example from Log4j 1.x is misleading. The SocketAppender does not
actually use a Layout. Configuring one will have no effect.
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration PUBLIC "-//APACHE//DTD LOG4J 1.2//EN" "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
<appender name="A1" class="org.apache.log4j.net.SocketAppender">
<param name="RemoteHost" value="localhost"/>
<param name="Port" value="5000"/>
<param name="LocationInfo" value="true"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%t %-5p %c{2} - %m%n"/>
</layout>
</appender>
<appender name="STDOUT" class="org.apache.log4j.ConsoleAppender">
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d %-5p [%t] %C{2} (%F:%L) - %m%n"/>
</layout>
</appender>
<category name="org.apache.log4j.xml">
<priority value="debug"/>
<appender-ref ref="A1"/>
</category>
<root>
<priority value="debug"/>
<appender-ref ref="STDOUT"/>
</root>
</log4j:configuration>
Log4j 2 XML configuration
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<appenders>
<Socket name="A1" host="localHost" port="5000">
<SerializedLayout/>
</Socket>
<Console name="STDOUT" target="SYSTEM_OUT">
<PatternLayout pattern="%d %-5p [%t] %C{2} (%F:%L) - %m%n"/>
</Console>
</appenders>
<loggers>
<logger name="org.apache.log4j.xml" level="debug">
<appender-ref ref="A1"/>
</logger>
<root level="debug">
<appender-ref ref="STDOUT"/>
</root>
</loggers>
</configuration>
Sample 4 - AsynchAppender
Log4j 1.x XML configuration using the AsynchAppender.
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration PUBLIC "-//APACHE//DTD LOG4J 1.2//EN" "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/" configDebug="true">
<appender name="ASYNC" class="org.apache.log4j.AsyncAppender">
<appender-ref ref="TEMP"/>
</appender>
<appender name="TEMP" class="org.apache.log4j.FileAppender">
<param name="File" value="temp"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d %-5p [%t] %C{2} (%F:%L) - %m%n"/>
</layout>
</appender>
<root>
<priority value="debug"/>
<appender-ref ref="ASYNC"/>
</root>
</log4j:configuration>
Log4j 2 XML configuration.
<?xml version="1.0" encoding="UTF-8"?>
<configuration status="debug">
<appenders>
<File name="TEMP" fileName="temp">
<PatternLayout pattern="%d %-5p [%t] %C{2} (%F:%L) - %m%n"/>
</File>
<Asynch name="ASYNC">
<appender-ref ref="TEMP"/>
</Asynch>
</appenders>
<loggers>
<root level="debug">
<appender-ref ref="ASYNC"/>
</root>
</loggers>
</configuration>
Sample 5 - AsynchAppender with Console and File
Log4j 1.x XML configuration using the AsynchAppender.
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration PUBLIC "-//APACHE//DTD LOG4J 1.2//EN" "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/" configDebug="true">
<appender name="ASYNC" class="org.apache.log4j.AsyncAppender">
<appender-ref ref="TEMP"/>
<appender-ref ref="CONSOLE"/>
</appender>
<appender name="CONSOLE" class="org.apache.log4j.ConsoleAppender">
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d %-5p [%t] %C{2} (%F:%L) - %m%n"/>
</layout>
</appender>
<appender name="TEMP" class="org.apache.log4j.FileAppender">
<param name="File" value="temp"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d %-5p [%t] %C{2} (%F:%L) - %m%n"/>
</layout>
</appender>
<root>
<priority value="debug"/>
<appender-ref ref="ASYNC"/>
</root>
</log4j:configuration>
Log4j 2 XML configuration. Note that the Asynch Appender should be configured after the appenders it
references. This will allow it to shutdown properly.
<?xml version="1.0" encoding="UTF-8"?>
<configuration status="debug">
<appenders>
<Console name="CONSOLE" target="SYSTEM_OUT">
<PatternLayout pattern="%d %-5p [%t] %C{2} (%F:%L) - %m%n"/>
</Console>
<File name="TEMP" fileName="temp">
<PatternLayout pattern="%d %-5p [%t] %C{2} (%F:%L) - %m%n"/>
</File>
<Asynch name="ASYNC">
<appender-ref ref="TEMP"/>
<appender-ref ref="CONSOLE"/>
</Asynch>
</appenders>
<loggers>
<root level="debug">
<appender-ref ref="ASYNC"/>
</root>
</loggers>
</configuration>