This is an automated email from the ASF dual-hosted git repository.

rpopma pushed a commit to branch asf-staging
in repository https://gitbox.apache.org/repos/asf/logging-log4j-site.git


The following commit(s) were added to refs/heads/asf-staging by this push:
     new 8b2cd91  Merge Log4j 1.x compatibility page into the Migration page
8b2cd91 is described below

commit 8b2cd917b0b481e0512342fd4886f52ad59050a4
Author: Remko Popma <rem...@yahoo.com>
AuthorDate: Sat Dec 25 20:07:14 2021 +0900

    Merge Log4j 1.x compatibility page into the Migration page
---
 log4j-2.17.0/manual/compatibility.html | 312 ++++++--------
 log4j-2.17.0/manual/migration.html     | 766 ++++++++++++++-------------------
 2 files changed, 450 insertions(+), 628 deletions(-)

diff --git a/log4j-2.17.0/manual/compatibility.html 
b/log4j-2.17.0/manual/compatibility.html
index 7a8b173..9760a77 100644
--- a/log4j-2.17.0/manual/compatibility.html
+++ b/log4j-2.17.0/manual/compatibility.html
@@ -40,200 +40,136 @@
           </ul>
         </div>
       </header>
-      <div class="row-fluid">
-        <header id="leftColumn" class="span2">
-          <nav class="well sidebar-nav">
-  <ul class="nav nav-list">
-   <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/home.png" alt="Apache Log4j™ 2" border="0"/> Apache 
Log4j™ 2</li>
-    <li><a href="../index.html" title="About"><span 
class="none"></span>About</a></li>
-    <li><a href="../download.html" title="Download"><span 
class="none"></span>Download</a></li>
-    <li><a href="../javadoc.html" title="Javadoc"><span 
class="icon-chevron-right"></span>Javadoc</a></li>
-    <li><a href="../maven-artifacts.html" title="Maven, Ivy, Gradle 
Artifacts"><span class="icon-chevron-right"></span>Maven, Ivy, Gradle 
Artifacts</a></li>
-    <li><a href="../runtime-dependencies.html" title="Runtime 
Dependencies"><span class="none"></span>Runtime Dependencies</a></li>
-    <li><a href="../changelog.html" title="Changelog"><span 
class="none"></span>Changelog</a></li>
-    <li><a href="../faq.html" title="FAQ"><span 
class="none"></span>FAQ</a></li>
-    <li><a href="../performance.html" title="Performance"><span 
class="icon-chevron-right"></span>Performance</a></li>
-    <li><a href="../articles.html" title="Articles and Tutorials"><span 
class="none"></span>Articles and Tutorials</a></li>
-    <li><a href="../security.html" title="Security"><span 
class="none"></span>Security</a></li>
-    <li><a href="../support.html" title="Support"><span 
class="none"></span>Support</a></li>
-    <li><a href="../thanks.html" title="Thanks"><span 
class="none"></span>Thanks</a></li>
-   <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/pencil.png" alt="For Contributors" border="0"/> For 
Contributors</li>
-    <li><a href="../build.html" title="Building Log4j from Source"><span 
class="none"></span>Building Log4j from Source</a></li>
-    <li><a href="../guidelines.html" title="Guidelines"><span 
class="none"></span>Guidelines</a></li>
-    <li><a href="../javastyle.html" title="Style Guide"><span 
class="none"></span>Style Guide</a></li>
-   <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/book.png" alt="Manual" border="0"/> Manual</li>
-    <li><a href="../manual/index.html" title="Introduction"><span 
class="none"></span>Introduction</a></li>
-    <li><a href="../manual/architecture.html" title="Architecture"><span 
class="none"></span>Architecture</a></li>
-    <li class="active"><a href="#"><span class="none"></span>Log4j 1.x 
Compatibility</a></li>
-    <li><a href="../manual/migration.html" title="Log4j 1.x Migration"><span 
class="none"></span>Log4j 1.x Migration</a></li>
-    <li><a href="../manual/api.html" title="Java API"><span 
class="icon-chevron-right"></span>Java API</a></li>
-    <li><a href="../manual/scala-api.html" title="Scala API"><span 
class="none"></span>Scala API</a></li>
-    <li><a href="../manual/configuration.html" title="Configuration"><span 
class="icon-chevron-right"></span>Configuration</a></li>
-    <li><a href="../manual/usage.html" title="Usage"><span 
class="icon-chevron-right"></span>Usage</a></li>
-    <li><a href="../manual/webapp.html" title="Web Applications and 
JSPs"><span class="icon-chevron-right"></span>Web Applications and JSPs</a></li>
-    <li><a href="../manual/lookups.html" title="Lookups"><span 
class="icon-chevron-right"></span>Lookups</a></li>
-    <li><a href="../manual/appenders.html" title="Appenders"><span 
class="icon-chevron-right"></span>Appenders</a></li>
-    <li><a href="../manual/layouts.html" title="Layouts"><span 
class="icon-chevron-right"></span>Layouts</a></li>
-    <li><a href="../manual/filters.html" title="Filters"><span 
class="icon-chevron-right"></span>Filters</a></li>
-    <li><a href="../manual/async.html" title="Async Loggers"><span 
class="icon-chevron-right"></span>Async Loggers</a></li>
-    <li><a href="../manual/garbagefree.html" title="Garbage-free 
Logging"><span class="icon-chevron-right"></span>Garbage-free Logging</a></li>
-    <li><a href="../manual/jmx.html" title="JMX"><span 
class="none"></span>JMX</a></li>
-    <li><a href="../manual/logsep.html" title="Logging Separation"><span 
class="none"></span>Logging Separation</a></li>
-    <li><a href="../manual/extending.html" title="Extending Log4j"><span 
class="icon-chevron-right"></span>Extending Log4j</a></li>
-    <li><a href="../manual/plugins.html" title="Plugins"><span 
class="icon-chevron-right"></span>Plugins</a></li>
-    <li><a href="../manual/customconfig.html" title="Programmatic Log4j 
Configuration"><span class="icon-chevron-right"></span>Programmatic Log4j 
Configuration</a></li>
-    <li><a href="../manual/customloglevels.html" title="Custom Log 
Levels"><span class="icon-chevron-right"></span>Custom Log Levels</a></li>
-   <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/tag.png" alt="Related Projects" border="0"/> Related 
Projects</li>
-    <li><a href="http://logging.apache.org/log4j/scala/index.html"; 
class="externalLink" title="Log4j-Scala"><span 
class="none"></span>Log4j-Scala</a></li>
-   <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/link.png" alt="Legacy Sites" border="0"/> Legacy 
Sites</li>
-    <li><a href="http://logging.apache.org/log4j/1.2/"; class="externalLink" 
title="Log4j 1.2 - End of Life"><span class="none"></span>Log4j 1.2 - End of 
Life</a></li>
-    <li><a href="http://logging.apache.org/log4j/log4j-2.3.1/"; 
class="externalLink" title="Log4j 2.3.1 - Java 6"><span 
class="none"></span>Log4j 2.3.1 - Java 6</a></li>
-    <li><a href="http://logging.apache.org/log4j/log4j-2.12.3"; 
class="externalLink" title="Log4j 2.12.3 - Java 7"><span 
class="none"></span>Log4j 2.12.3 - Java 7</a></li>
-   <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/cog.png" alt="Components" border="0"/> Components</li>
-    <li><a href="../log4j-api/index.html" title="API"><span 
class="none"></span>API</a></li>
-    <li><a href="../log4j-core/index.html" title="Implementation"><span 
class="none"></span>Implementation</a></li>
-    <li><a href="../log4j-jcl/index.html" title="Commons Logging Bridge"><span 
class="none"></span>Commons Logging Bridge</a></li>
-    <li><a href="../log4j-1.2-api/index.html" title="Log4j 1.2 API"><span 
class="none"></span>Log4j 1.2 API</a></li>
-    <li><a href="../log4j-slf4j-impl/index.html" title="SLF4J Binding"><span 
class="none"></span>SLF4J Binding</a></li>
-    <li><a href="../log4j-jul/index.html" title="JUL Adapter"><span 
class="none"></span>JUL Adapter</a></li>
-    <li><a href="../log4j-jpl/index.html" title="JDK Platform Logger"><span 
class="none"></span>JDK Platform Logger</a></li>
-    <li><a href="../log4j-to-slf4j/index.html" title="Log4j 2 to SLF4J 
Adapter"><span class="none"></span>Log4j 2 to SLF4J Adapter</a></li>
-    <li><a href="../log4j-flume-ng/index.html" title="Apache Flume 
Appender"><span class="none"></span>Apache Flume Appender</a></li>
-    <li><a href="../log4j-taglib/index.html" title="Log4j Tag Library"><span 
class="none"></span>Log4j Tag Library</a></li>
-    <li><a href="../log4j-jmx-gui/index.html" title="Log4j JMX GUI"><span 
class="none"></span>Log4j JMX GUI</a></li>
-    <li><a href="../log4j-web/index.html" title="Log4j Web Application 
Support"><span class="none"></span>Log4j Web Application Support</a></li>
-    <li><a href="../log4j-jakarta-web/index.html" title="Log4j Jakarta Web 
Application Support"><span class="none"></span>Log4j Jakarta Web Application 
Support</a></li>
-    <li><a href="../log4j-appserver/index.html" title="Log4j Application 
Server Integration"><span class="none"></span>Log4j Application Server 
Integration</a></li>
-    <li><a href="../log4j-couchdb/index.html" title="Log4j CouchDB 
appender"><span class="none"></span>Log4j CouchDB appender</a></li>
-    <li><a href="../log4j-mongodb3/index.html" title="Log4j MongoDB3 
appender"><span class="none"></span>Log4j MongoDB3 appender</a></li>
-    <li><a href="../log4j-mongodb4/index.html" title="Log4j MongoDB4 
appender"><span class="none"></span>Log4j MongoDB4 appender</a></li>
-    <li><a href="../log4j-cassandra/index.html" title="Log4j Cassandra 
appender"><span class="none"></span>Log4j Cassandra appender</a></li>
-    <li><a href="../log4j-iostreams/index.html" title="Log4j IO Streams"><span 
class="none"></span>Log4j IO Streams</a></li>
-    <li><a href="../log4j-liquibase/index.html" title="Log4j Liquibase 
Binding"><span class="none"></span>Log4j Liquibase Binding</a></li>
-    <li><a href="../log4j-docker/index.html" title="Log4j Docker 
Support"><span class="none"></span>Log4j Docker Support</a></li>
-    <li><a href="../log4j-spring-boot/index.html" title="Log4j Spring 
Boot"><span class="none"></span>Log4j Spring Boot</a></li>
-    <li><a 
href="../log4j-spring-cloud-config/log4j-spring-cloud-config-client/index.html" 
title="Log4j Spring Cloud Config Client"><span class="none"></span>Log4j Spring 
Cloud Config Client</a></li>
-   <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/info.png" alt="Project Information" border="0"/> Project 
Information</li>
-    <li><a href="../dependency-convergence.html" title="Dependency 
Convergence"><span class="none"></span>Dependency Convergence</a></li>
-    <li><a href="../dependency-management.html" title="Dependency 
Management"><span class="none"></span>Dependency Management</a></li>
-    <li><a href="../team-list.html" title="Project Team"><span 
class="none"></span>Project Team</a></li>
-    <li><a href="../mail-lists.html" title="Mailing Lists"><span 
class="none"></span>Mailing Lists</a></li>
-    <li><a href="../issue-tracking.html" title="Issue Tracking"><span 
class="none"></span>Issue Tracking</a></li>
-    <li><a href="../license.html" title="Project License"><span 
class="none"></span>Project License</a></li>
-    <li><a href="../source-repository.html" title="Source Repository"><span 
class="none"></span>Source Repository</a></li>
-    <li><a href="../project-summary.html" title="Project Summary"><span 
class="none"></span>Project Summary</a></li>
-   <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/layers.png" alt="Project Reports" border="0"/> Project 
Reports</li>
-    <li><a href="../changes-report.html" title="Changes Report"><span 
class="none"></span>Changes Report</a></li>
-    <li><a href="../jira-report.html" title="JIRA Report"><span 
class="none"></span>JIRA Report</a></li>
-    <li><a href="../rat-report.html" title="RAT Report"><span 
class="none"></span>RAT Report</a></li>
-  </ul>
-          </nav>
-          <div class="well sidebar-nav">
-            <hr />
-            <div id="poweredBy">
-              <div class="clear"></div>
-              <div class="clear"></div>
-              <div class="clear"></div>
-<a href="http://maven.apache.org/"; title="Built by Maven" 
class="poweredBy"><img class="builtBy" alt="Built by Maven" 
src="../images/logos/maven-feather.png" /></a>
-            </div>
-          </div>
-        </header>
-        <main id="bodyColumn"  class="span10" >
-<!-- vim: set syn=markdown : -->
-<!--
- Licensed to the Apache Software Foundation (ASF) under one or more
- contributor license agreements. See the NOTICE file distributed with
- this work for additional information regarding copyright ownership.
- The ASF licenses this file to You under the Apache License, Version 2.0
- (the "License"); you may not use this file except in compliance with
- the License. You may obtain a copy of the License at
-
-         http://www.apache.org/licenses/LICENSE-2.0
-
- Unless required by applicable law or agreed to in writing, software
- distributed under the License is distributed on an "AS IS" BASIS,
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- See the License for the specific language governing permissions and
- limitations under the License.
--->
-<h1>Log4j 2 Compatibility with Log4j 1</h1><section>
-<h2><a name="API_Compatibility"></a>API Compatibility</h2>
-<p>Log4j 2 provides support for the Log4j 1 logging methods by providing 
alternate implementations of the classes containing those methods. These 
classes may be found in the log4j-1.2-api jar distributed with the project. All 
calls to perform logging will result in the data passed to the logging methods 
to be forwarded to the Log4j2 API where they can be processed by 
implementations of the Log4j 2 API.</p></section><section>
-<h2><a name="Configuration_Compatibility"></a>Configuration Compatibility</h2>
-<p>Log4j 2 provides experimental support for Log4j 1 configuration files. 
Configuration of the Appenders, Layouts and Filters that were provided in the 
Log4j 1 distribution will be redirected to their Log4j 2 counterparts - with 
the exception of the implemented Rewrite Policies. This means that although the 
while the behavior of these components will be similar they may not be exactly 
the same. For example, the XML generated by the XMLLayout may not exactly match 
the XML generated by the [...]
-<p>In addition, Log4j 2 supports custom Log4j 1 Appenders, Filters, and 
Layouts with some constraints. Since the original Log4j 1 components may not be 
present in Log4j 2, custom components that extend them will fail.</p>
-<p>As support for Log4j 1 is an experimental feature one of the following 
steps must be taken to enable it:</p>
-<ol style="list-style-type: decimal">
-
-<li>Set the system property &#x201c;log4j1.compatibility&#x201d; to a value of 
&#x201c;true&#x201d;. Log4j 2 will then add log4j.properties, 
log4j-test.properties, log4j.xml and log4j-test.xml to the configuration files 
it searches for on the class path.</li>
-<li>Set the Log4j 1 system property &#x201c;log4j.configuration&#x201d; to the 
location of the log4j 1 configuration file. The files must have a file 
extension of either &#x201c;.properties&#x201d; or &#x201c;.xml&#x201d;.</li>
-</ol></section><section>
-<h2><a name="Supported_Components"></a>Supported Components</h2><section>
-<h3><a name="Appenders"></a>Appenders</h3>
-<ul>
-
-<li>AsyncAppender</li>
-<li>ConsoleAppender</li>
-<li>DailyRollingFileAppender</li>
-<li>FileAppender</li>
-<li>NullAppender</li>
-<li>RewriteAppender (limited)</li>
-<li>RollingFileAppender</li>
-<li>SyslogAppender</li>
-</ul></section></section><section>
-<h2><a name="Filters"></a>Filters</h2>
-<ul>
-
-<li>DenyAllFilter</li>
-<li>LevelMatchFilter</li>
-<li>LevelRangeFilter</li>
-<li>StringMatchFilter</li>
-</ul></section><section>
-<h2><a name="Layouts"></a>Layouts</h2>
-<ul>
-
-<li>HtmlLayout</li>
-<li>PatternLayout</li>
-<li>SimpleLayout</li>
-<li>TTCCLayout</li>
-<li>XmlLayout</li>
-</ul></section><section>
-<h2><a name="Rewrite_Policies"></a>Rewrite Policies</h2>
-<ul>
-
-<li>MapRewritePolicy</li>
-<li>PropertyRewritePolicy</li>
-</ul></section><section>
-<h2><a name="Unsupported_or_Unimplemented_Components"></a>Unsupported or 
Unimplemented Components</h2><section>
-<h3><a name="Appenders"></a>Appenders</h3>
-<ul>
+        <div class="row-fluid">
+            <header id="leftColumn" class="span2">
+                <nav class="well sidebar-nav">
+                    <ul class="nav nav-list">
+                        <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/home.png" alt="Apache Log4j™ 2" border="0"/> Apache 
Log4j™ 2</li>
+                        <li><a href="../index.html" title="About"><span 
class="none"></span>About</a></li>
+                        <li><a href="../download.html" title="Download"><span 
class="none"></span>Download</a></li>
+                        <li><a href="../javadoc.html" title="Javadoc"><span 
class="icon-chevron-right"></span>Javadoc</a></li>
+                        <li><a href="../maven-artifacts.html" title="Maven, 
Ivy, Gradle Artifacts"><span class="icon-chevron-right"></span>Maven, Ivy, 
Gradle Artifacts</a></li>
+                        <li><a href="../runtime-dependencies.html" 
title="Runtime Dependencies"><span class="none"></span>Runtime 
Dependencies</a></li>
+                        <li><a href="../changelog.html" 
title="Changelog"><span class="none"></span>Changelog</a></li>
+                        <li><a href="../faq.html" title="FAQ"><span 
class="none"></span>FAQ</a></li>
+                        <li><a href="../performance.html" 
title="Performance"><span class="icon-chevron-right"></span>Performance</a></li>
+                        <li><a href="../articles.html" title="Articles and 
Tutorials"><span class="none"></span>Articles and Tutorials</a></li>
+                        <li><a href="../security.html" title="Security"><span 
class="none"></span>Security</a></li>
+                        <li><a href="../support.html" title="Support"><span 
class="none"></span>Support</a></li>
+                        <li><a href="../thanks.html" title="Thanks"><span 
class="none"></span>Thanks</a></li>
+                        <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/pencil.png" alt="For Contributors" border="0"/> For 
Contributors</li>
+                        <li><a href="../build.html" title="Building Log4j from 
Source"><span class="none"></span>Building Log4j from Source</a></li>
+                        <li><a href="../guidelines.html" 
title="Guidelines"><span class="none"></span>Guidelines</a></li>
+                        <li><a href="../javastyle.html" title="Style 
Guide"><span class="none"></span>Style Guide</a></li>
+                        <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/book.png" alt="Manual" border="0"/> Manual</li>
+                        <li><a href="../manual/index.html" 
title="Introduction"><span class="none"></span>Introduction</a></li>
+                        <li><a href="../manual/architecture.html" 
title="Architecture"><span class="none"></span>Architecture</a></li>
+                        <li><a href="../manual/migration.html" title="Log4j 
1.x Migration"><span class="icon-chevron-right"></span>Log4j 1.x 
Migration</a></li>
+                        <li><a href="../manual/api.html" title="Java 
API"><span class="icon-chevron-right"></span>Java API</a></li>
+                        <li><a href="../manual/scala-api.html" title="Scala 
API"><span class="none"></span>Scala API</a></li>
+                        <li><a href="../manual/configuration.html" 
title="Configuration"><span 
class="icon-chevron-right"></span>Configuration</a></li>
+                        <li><a href="../manual/usage.html" title="Usage"><span 
class="icon-chevron-right"></span>Usage</a></li>
+                        <li><a href="../manual/webapp.html" title="Web 
Applications and JSPs"><span class="icon-chevron-right"></span>Web Applications 
and JSPs</a></li>
+                        <li><a href="../manual/lookups.html" 
title="Lookups"><span class="icon-chevron-right"></span>Lookups</a></li>
+                        <li><a href="../manual/appenders.html" 
title="Appenders"><span class="icon-chevron-right"></span>Appenders</a></li>
+                        <li><a href="../manual/layouts.html" 
title="Layouts"><span class="icon-chevron-right"></span>Layouts</a></li>
+                        <li><a href="../manual/filters.html" 
title="Filters"><span class="icon-chevron-right"></span>Filters</a></li>
+                        <li><a href="../manual/async.html" title="Async 
Loggers"><span class="icon-chevron-right"></span>Async Loggers</a></li>
+                        <li><a href="../manual/garbagefree.html" 
title="Garbage-free Logging"><span 
class="icon-chevron-right"></span>Garbage-free Logging</a></li>
+                        <li><a href="../manual/jmx.html" title="JMX"><span 
class="none"></span>JMX</a></li>
+                        <li><a href="../manual/logsep.html" title="Logging 
Separation"><span class="none"></span>Logging Separation</a></li>
+                        <li><a href="../manual/extending.html" 
title="Extending Log4j"><span class="icon-chevron-right"></span>Extending 
Log4j</a></li>
+                        <li><a href="../manual/plugins.html" 
title="Plugins"><span class="icon-chevron-right"></span>Plugins</a></li>
+                        <li><a href="../manual/customconfig.html" 
title="Programmatic Log4j Configuration"><span 
class="icon-chevron-right"></span>Programmatic Log4j Configuration</a></li>
+                        <li><a href="../manual/customloglevels.html" 
title="Custom Log Levels"><span class="icon-chevron-right"></span>Custom Log 
Levels</a></li>
+                        <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/tag.png" alt="Related Projects" border="0"/> Related 
Projects</li>
+                        <li><a 
href="http://logging.apache.org/log4j/scala/index.html"; class="externalLink" 
title="Log4j-Scala"><span class="none"></span>Log4j-Scala</a></li>
+                        <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/link.png" alt="Legacy Sites" border="0"/> Legacy 
Sites</li>
+                        <li><a href="http://logging.apache.org/log4j/1.2/"; 
class="externalLink" title="Log4j 1.2 - End of Life"><span 
class="none"></span>Log4j 1.2 - End of Life</a></li>
+                        <li><a 
href="http://logging.apache.org/log4j/log4j-2.3.1/"; class="externalLink" 
title="Log4j 2.3.1 - Java 6"><span class="none"></span>Log4j 2.3.1 - Java 
6</a></li>
+                        <li><a 
href="http://logging.apache.org/log4j/log4j-2.12.3/"; class="externalLink" 
title="Log4j 2.12.3 - Java 7"><span class="none"></span>Log4j 2.12.3 - Java 
7</a></li>
+                        <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/cog.png" alt="Components" border="0"/> Components</li>
+                        <li><a href="../log4j-api/index.html" 
title="API"><span class="none"></span>API</a></li>
+                        <li><a href="../log4j-core/index.html" 
title="Implementation"><span class="none"></span>Implementation</a></li>
+                        <li><a href="../log4j-jcl/index.html" title="Commons 
Logging Bridge"><span class="none"></span>Commons Logging Bridge</a></li>
+                        <li><a href="../log4j-1.2-api/index.html" title="Log4j 
1.2 API"><span class="none"></span>Log4j 1.2 API</a></li>
+                        <li><a href="../log4j-slf4j-impl/index.html" 
title="SLF4J Binding"><span class="none"></span>SLF4J Binding</a></li>
+                        <li><a href="../log4j-jul/index.html" title="JUL 
Adapter"><span class="none"></span>JUL Adapter</a></li>
+                        <li><a href="../log4j-jpl/index.html" title="JDK 
Platform Logger"><span class="none"></span>JDK Platform Logger</a></li>
+                        <li><a href="../log4j-to-slf4j/index.html" 
title="Log4j 2 to SLF4J Adapter"><span class="none"></span>Log4j 2 to SLF4J 
Adapter</a></li>
+                        <li><a href="../log4j-flume-ng/index.html" 
title="Apache Flume Appender"><span class="none"></span>Apache Flume 
Appender</a></li>
+                        <li><a href="../log4j-taglib/index.html" title="Log4j 
Tag Library"><span class="none"></span>Log4j Tag Library</a></li>
+                        <li><a href="../log4j-jmx-gui/index.html" title="Log4j 
JMX GUI"><span class="none"></span>Log4j JMX GUI</a></li>
+                        <li><a href="../log4j-web/index.html" title="Log4j Web 
Application Support"><span class="none"></span>Log4j Web Application 
Support</a></li>
+                        <li><a href="../log4j-jakarta-web/index.html" 
title="Log4j Jakarta Web Application Support"><span class="none"></span>Log4j 
Jakarta Web Application Support</a></li>
+                        <li><a href="../log4j-appserver/index.html" 
title="Log4j Application Server Integration"><span class="none"></span>Log4j 
Application Server Integration</a></li>
+                        <li><a href="../log4j-couchdb/index.html" title="Log4j 
CouchDB appender"><span class="none"></span>Log4j CouchDB appender</a></li>
+                        <li><a href="../log4j-mongodb3/index.html" 
title="Log4j MongoDB3 appender"><span class="none"></span>Log4j MongoDB3 
appender</a></li>
+                        <li><a href="../log4j-mongodb4/index.html" 
title="Log4j MongoDB4 appender"><span class="none"></span>Log4j MongoDB4 
appender</a></li>
+                        <li><a href="../log4j-cassandra/index.html" 
title="Log4j Cassandra appender"><span class="none"></span>Log4j Cassandra 
appender</a></li>
+                        <li><a href="../log4j-iostreams/index.html" 
title="Log4j IO Streams"><span class="none"></span>Log4j IO Streams</a></li>
+                        <li><a href="../log4j-liquibase/index.html" 
title="Log4j Liquibase Binding"><span class="none"></span>Log4j Liquibase 
Binding</a></li>
+                        <li><a href="../log4j-docker/index.html" title="Log4j 
Docker Support"><span class="none"></span>Log4j Docker Support</a></li>
+                        <li><a href="../log4j-spring-boot/index.html" 
title="Log4j Spring Boot"><span class="none"></span>Log4j Spring Boot</a></li>
+                        <li><a 
href="../log4j-spring-cloud-config/log4j-spring-cloud-config-client/index.html" 
title="Log4j Spring Cloud Config Client"><span class="none"></span>Log4j Spring 
Cloud Config Client</a></li>
+                        <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/info.png" alt="Project Information" border="0"/> Project 
Information</li>
+                        <li><a href="../dependency-convergence.html" 
title="Dependency Convergence"><span class="none"></span>Dependency 
Convergence</a></li>
+                        <li><a href="../dependency-management.html" 
title="Dependency Management"><span class="none"></span>Dependency 
Management</a></li>
+                        <li><a href="../team-list.html" title="Project 
Team"><span class="none"></span>Project Team</a></li>
+                        <li><a href="../mail-lists.html" title="Mailing 
Lists"><span class="none"></span>Mailing Lists</a></li>
+                        <li><a href="../issue-tracking.html" title="Issue 
Tracking"><span class="none"></span>Issue Tracking</a></li>
+                        <li><a href="../license.html" title="Project 
License"><span class="none"></span>Project License</a></li>
+                        <li><a href="../source-repository.html" title="Source 
Repository"><span class="none"></span>Source Repository</a></li>
+                        <li><a href="../project-summary.html" title="Project 
Summary"><span class="none"></span>Project Summary</a></li>
+                        <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/layers.png" alt="Project Reports" border="0"/> Project 
Reports</li>
+                        <li><a href="../changes-report.html" title="Changes 
Report"><span class="none"></span>Changes Report</a></li>
+                        <li><a href="../jira-report.html" title="JIRA 
Report"><span class="none"></span>JIRA Report</a></li>
+                        <li><a href="../rat-report.html" title="RAT 
Report"><span class="none"></span>RAT Report</a></li>
+                    </ul>
+                </nav>
+                <div class="well sidebar-nav">
+                    <hr />
+                    <div id="poweredBy">
+                        <div class="clear"></div>
+                        <div class="clear"></div>
+                        <div class="clear"></div>
+                        <a href="http://maven.apache.org/"; title="Built by 
Maven" class="poweredBy"><img class="builtBy" alt="Built by Maven" 
src="../images/logos/maven-feather.png" /></a>
+                    </div>
+                </div>
+            </header>
+            <main id="bodyColumn"  class="span10" >
+                <!-- vim: set syn=markdown : -->
+                <!--
+                 Licensed to the Apache Software Foundation (ASF) under one or 
more
+                 contributor license agreements. See the NOTICE file 
distributed with
+                 this work for additional information regarding copyright 
ownership.
+                 The ASF licenses this file to You under the Apache License, 
Version 2.0
+                 (the "License"); you may not use this file except in 
compliance with
+                 the License. You may obtain a copy of the License at
 
-<li>JDBCAppender (cannot be mapped to Log4j 2&#x2019;s JdbcAppender)</li>
-<li>JMSAppender</li>
-<li>SMTPAppender</li>
-<li>SocketAppender (Requires the use of the SerializedLayout which is a 
security risk)</li>
-<li>SocketHubAppender (Requires the use of the SerializedLayout which is a 
securiy risk)</li>
-<li>TelnetAppender (Security risk)</li>
-</ul></section></section><section>
-<h2><a name="Rewrite_Policies"></a>Rewrite Policies</h2>
-<ul>
+                         http://www.apache.org/licenses/LICENSE-2.0
 
-<li>ReflectionRewritePolicy</li>
-<li>Custom rewrite policies since LoggingEvent is currently a no-op.</li>
-</ul><section>
-<h3><a name="Renderers"></a>Renderers</h3>
-<p>Log4j 2 currently ignores renderers.</p></section></section>
-        </main>
-      </div>
+                 Unless required by applicable law or agreed to in writing, 
software
+                 distributed under the License is distributed on an "AS IS" 
BASIS,
+                 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express 
or implied.
+                 See the License for the specific language governing 
permissions and
+                 limitations under the License.
+                -->
+                <!-- NOTE: do not delete this page: external pages may be 
linking to it -->
+                <section>
+                    <h2><a name="Log4j_2_Compatibility_with_Log4j_1"></a>Log4j 
2 Compatibility with Log4j 1</h2>
+                    <p>See the <a href="migration.html#Log4j1.2Bridge">Log4j 
1.x bridge (log4j-1.2-api)</a> section of the Log4j 1.x Migration 
page.</p></section>
+            </main>
+        </div>
     </div>
     <hr/>
     <footer>
-      <div class="container-fluid">
-        <div class="row-fluid">
-<p align="center">Copyright &copy; 1999-2021 <a class="external" 
href="http://www.apache.org";>The Apache Software Foundation</a>. All Rights 
Reserved.<br>
-      Apache Logging, Apache Log4j, Log4j, Apache, the Apache feather logo, 
and the Apache Logging project logo are trademarks of The Apache Software 
Foundation.</p>
+        <div class="container-fluid">
+            <div class="row-fluid">
+                <p align="center">Copyright &copy; 1999-2021 <a 
class="external" href="http://www.apache.org";>The Apache Software 
Foundation</a>. All Rights Reserved.<br>
+                    Apache Logging, Apache Log4j, Log4j, Apache, the Apache 
feather logo, and the Apache Logging project logo are trademarks of The Apache 
Software Foundation.</p>
+            </div>
         </div>
-      </div>
     </footer>
   </body>
 </html>
diff --git a/log4j-2.17.0/manual/migration.html 
b/log4j-2.17.0/manual/migration.html
index a3194a0..a419e18 100644
--- a/log4j-2.17.0/manual/migration.html
+++ b/log4j-2.17.0/manual/migration.html
@@ -41,359 +41,257 @@
           </ul>
         </div>
       </header>
-      <div class="row-fluid">
-        <header id="leftColumn" class="span2">
-          <nav class="well sidebar-nav">
-  <ul class="nav nav-list">
-   <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/home.png" alt="Apache Log4j™ 2" border="0"/> Apache 
Log4j™ 2</li>
-    <li><a href="../index.html" title="About"><span 
class="none"></span>About</a></li>
-    <li><a href="../download.html" title="Download"><span 
class="none"></span>Download</a></li>
-    <li><a href="../javadoc.html" title="Javadoc"><span 
class="icon-chevron-right"></span>Javadoc</a></li>
-    <li><a href="../maven-artifacts.html" title="Maven, Ivy, Gradle 
Artifacts"><span class="icon-chevron-right"></span>Maven, Ivy, Gradle 
Artifacts</a></li>
-    <li><a href="../runtime-dependencies.html" title="Runtime 
Dependencies"><span class="none"></span>Runtime Dependencies</a></li>
-    <li><a href="../changelog.html" title="Changelog"><span 
class="none"></span>Changelog</a></li>
-    <li><a href="../faq.html" title="FAQ"><span 
class="none"></span>FAQ</a></li>
-    <li><a href="../performance.html" title="Performance"><span 
class="icon-chevron-right"></span>Performance</a></li>
-    <li><a href="../articles.html" title="Articles and Tutorials"><span 
class="none"></span>Articles and Tutorials</a></li>
-    <li><a href="../security.html" title="Security"><span 
class="none"></span>Security</a></li>
-    <li><a href="../support.html" title="Support"><span 
class="none"></span>Support</a></li>
-    <li><a href="../thanks.html" title="Thanks"><span 
class="none"></span>Thanks</a></li>
-   <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/pencil.png" alt="For Contributors" border="0"/> For 
Contributors</li>
-    <li><a href="../build.html" title="Building Log4j from Source"><span 
class="none"></span>Building Log4j from Source</a></li>
-    <li><a href="../guidelines.html" title="Guidelines"><span 
class="none"></span>Guidelines</a></li>
-    <li><a href="../javastyle.html" title="Style Guide"><span 
class="none"></span>Style Guide</a></li>
-   <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/book.png" alt="Manual" border="0"/> Manual</li>
-    <li><a href="../manual/index.html" title="Introduction"><span 
class="none"></span>Introduction</a></li>
-    <li><a href="../manual/architecture.html" title="Architecture"><span 
class="none"></span>Architecture</a></li>
-    <li><a href="../manual/compatibility.html" title="Log4j 1.x 
Compatibility"><span class="none"></span>Log4j 1.x Compatibility</a></li>
-    <li class="active"><a href="#"><span class="none"></span>Log4j 1.x 
Migration</a></li>
-    <li><a href="../manual/api.html" title="Java API"><span 
class="icon-chevron-right"></span>Java API</a></li>
-    <li><a href="../manual/scala-api.html" title="Scala API"><span 
class="none"></span>Scala API</a></li>
-    <li><a href="../manual/configuration.html" title="Configuration"><span 
class="icon-chevron-right"></span>Configuration</a></li>
-    <li><a href="../manual/usage.html" title="Usage"><span 
class="icon-chevron-right"></span>Usage</a></li>
-    <li><a href="../manual/webapp.html" title="Web Applications and 
JSPs"><span class="icon-chevron-right"></span>Web Applications and JSPs</a></li>
-    <li><a href="../manual/lookups.html" title="Lookups"><span 
class="icon-chevron-right"></span>Lookups</a></li>
-    <li><a href="../manual/appenders.html" title="Appenders"><span 
class="icon-chevron-right"></span>Appenders</a></li>
-    <li><a href="../manual/layouts.html" title="Layouts"><span 
class="icon-chevron-right"></span>Layouts</a></li>
-    <li><a href="../manual/filters.html" title="Filters"><span 
class="icon-chevron-right"></span>Filters</a></li>
-    <li><a href="../manual/async.html" title="Async Loggers"><span 
class="icon-chevron-right"></span>Async Loggers</a></li>
-    <li><a href="../manual/garbagefree.html" title="Garbage-free 
Logging"><span class="icon-chevron-right"></span>Garbage-free Logging</a></li>
-    <li><a href="../manual/jmx.html" title="JMX"><span 
class="none"></span>JMX</a></li>
-    <li><a href="../manual/logsep.html" title="Logging Separation"><span 
class="none"></span>Logging Separation</a></li>
-    <li><a href="../manual/extending.html" title="Extending Log4j"><span 
class="icon-chevron-right"></span>Extending Log4j</a></li>
-    <li><a href="../manual/plugins.html" title="Plugins"><span 
class="icon-chevron-right"></span>Plugins</a></li>
-    <li><a href="../manual/customconfig.html" title="Programmatic Log4j 
Configuration"><span class="icon-chevron-right"></span>Programmatic Log4j 
Configuration</a></li>
-    <li><a href="../manual/customloglevels.html" title="Custom Log 
Levels"><span class="icon-chevron-right"></span>Custom Log Levels</a></li>
-   <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/tag.png" alt="Related Projects" border="0"/> Related 
Projects</li>
-    <li><a href="http://logging.apache.org/log4j/scala/index.html"; 
class="externalLink" title="Log4j-Scala"><span 
class="none"></span>Log4j-Scala</a></li>
-   <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/link.png" alt="Legacy Sites" border="0"/> Legacy 
Sites</li>
-    <li><a href="http://logging.apache.org/log4j/1.2/"; class="externalLink" 
title="Log4j 1.2 - End of Life"><span class="none"></span>Log4j 1.2 - End of 
Life</a></li>
-    <li><a href="http://logging.apache.org/log4j/log4j-2.3.1/"; 
class="externalLink" title="Log4j 2.3.1 - Java 6"><span 
class="none"></span>Log4j 2.3.1 - Java 6</a></li>
-    <li><a href="http://logging.apache.org/log4j/log4j-2.12.3"; 
class="externalLink" title="Log4j 2.12.3 - Java 7"><span 
class="none"></span>Log4j 2.12.3 - Java 7</a></li>
-   <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/cog.png" alt="Components" border="0"/> Components</li>
-    <li><a href="../log4j-api/index.html" title="API"><span 
class="none"></span>API</a></li>
-    <li><a href="../log4j-core/index.html" title="Implementation"><span 
class="none"></span>Implementation</a></li>
-    <li><a href="../log4j-jcl/index.html" title="Commons Logging Bridge"><span 
class="none"></span>Commons Logging Bridge</a></li>
-    <li><a href="../log4j-1.2-api/index.html" title="Log4j 1.2 API"><span 
class="none"></span>Log4j 1.2 API</a></li>
-    <li><a href="../log4j-slf4j-impl/index.html" title="SLF4J Binding"><span 
class="none"></span>SLF4J Binding</a></li>
-    <li><a href="../log4j-jul/index.html" title="JUL Adapter"><span 
class="none"></span>JUL Adapter</a></li>
-    <li><a href="../log4j-jpl/index.html" title="JDK Platform Logger"><span 
class="none"></span>JDK Platform Logger</a></li>
-    <li><a href="../log4j-to-slf4j/index.html" title="Log4j 2 to SLF4J 
Adapter"><span class="none"></span>Log4j 2 to SLF4J Adapter</a></li>
-    <li><a href="../log4j-flume-ng/index.html" title="Apache Flume 
Appender"><span class="none"></span>Apache Flume Appender</a></li>
-    <li><a href="../log4j-taglib/index.html" title="Log4j Tag Library"><span 
class="none"></span>Log4j Tag Library</a></li>
-    <li><a href="../log4j-jmx-gui/index.html" title="Log4j JMX GUI"><span 
class="none"></span>Log4j JMX GUI</a></li>
-    <li><a href="../log4j-web/index.html" title="Log4j Web Application 
Support"><span class="none"></span>Log4j Web Application Support</a></li>
-    <li><a href="../log4j-jakarta-web/index.html" title="Log4j Jakarta Web 
Application Support"><span class="none"></span>Log4j Jakarta Web Application 
Support</a></li>
-    <li><a href="../log4j-appserver/index.html" title="Log4j Application 
Server Integration"><span class="none"></span>Log4j Application Server 
Integration</a></li>
-    <li><a href="../log4j-couchdb/index.html" title="Log4j CouchDB 
appender"><span class="none"></span>Log4j CouchDB appender</a></li>
-    <li><a href="../log4j-mongodb3/index.html" title="Log4j MongoDB3 
appender"><span class="none"></span>Log4j MongoDB3 appender</a></li>
-    <li><a href="../log4j-mongodb4/index.html" title="Log4j MongoDB4 
appender"><span class="none"></span>Log4j MongoDB4 appender</a></li>
-    <li><a href="../log4j-cassandra/index.html" title="Log4j Cassandra 
appender"><span class="none"></span>Log4j Cassandra appender</a></li>
-    <li><a href="../log4j-iostreams/index.html" title="Log4j IO Streams"><span 
class="none"></span>Log4j IO Streams</a></li>
-    <li><a href="../log4j-liquibase/index.html" title="Log4j Liquibase 
Binding"><span class="none"></span>Log4j Liquibase Binding</a></li>
-    <li><a href="../log4j-docker/index.html" title="Log4j Docker 
Support"><span class="none"></span>Log4j Docker Support</a></li>
-    <li><a href="../log4j-spring-boot/index.html" title="Log4j Spring 
Boot"><span class="none"></span>Log4j Spring Boot</a></li>
-    <li><a 
href="../log4j-spring-cloud-config/log4j-spring-cloud-config-client/index.html" 
title="Log4j Spring Cloud Config Client"><span class="none"></span>Log4j Spring 
Cloud Config Client</a></li>
-   <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/info.png" alt="Project Information" border="0"/> Project 
Information</li>
-    <li><a href="../dependency-convergence.html" title="Dependency 
Convergence"><span class="none"></span>Dependency Convergence</a></li>
-    <li><a href="../dependency-management.html" title="Dependency 
Management"><span class="none"></span>Dependency Management</a></li>
-    <li><a href="../team-list.html" title="Project Team"><span 
class="none"></span>Project Team</a></li>
-    <li><a href="../mail-lists.html" title="Mailing Lists"><span 
class="none"></span>Mailing Lists</a></li>
-    <li><a href="../issue-tracking.html" title="Issue Tracking"><span 
class="none"></span>Issue Tracking</a></li>
-    <li><a href="../license.html" title="Project License"><span 
class="none"></span>Project License</a></li>
-    <li><a href="../source-repository.html" title="Source Repository"><span 
class="none"></span>Source Repository</a></li>
-    <li><a href="../project-summary.html" title="Project Summary"><span 
class="none"></span>Project Summary</a></li>
-   <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/layers.png" alt="Project Reports" border="0"/> Project 
Reports</li>
-    <li><a href="../changes-report.html" title="Changes Report"><span 
class="none"></span>Changes Report</a></li>
-    <li><a href="../jira-report.html" title="JIRA Report"><span 
class="none"></span>JIRA Report</a></li>
-    <li><a href="../rat-report.html" title="RAT Report"><span 
class="none"></span>RAT Report</a></li>
-  </ul>
-          </nav>
-          <div class="well sidebar-nav">
-            <hr />
-            <div id="poweredBy">
-              <div class="clear"></div>
-              <div class="clear"></div>
-              <div class="clear"></div>
-<a href="http://maven.apache.org/"; title="Built by Maven" 
class="poweredBy"><img class="builtBy" alt="Built by Maven" 
src="../images/logos/maven-feather.png" /></a>
-            </div>
-          </div>
-        </header>
-
-          <main id="bodyColumn"  class="span10" >
-
-
-              <section>
-                  <h2><a name="Migrating_from_Log4j_1.x_to_2.x"></a>Migrating 
from Log4j 1.x to 2.x</h2>
-
-                  <p>
-                      This page explains how to migrate applications or 
libraries currently using the Log4j 1.x API
-                      to use Log4j v2 as their main logging framework.
-                  </p>
-                  <a name="Log4j1.2Bridge"></a>
-                  <section>
-                      <h3><a 
name="Option_1:_use_the_Log4j_1.x_bridge_.28log4j-1.2-api.29"></a>Option 1: use 
the Log4j 1.x bridge (log4j-1.2-api)</h3>
-
-                      <p>
-                          You may be able to convert an application to Log4j 2 
<i>without any code changes</i>
-                          by replacing the Log4j 1.x jar file with Log4j 2's 
log4j-1.2-api.jar.
-                      </p>
-
-                      <p>
-                          The Log4j 1.x bridge is useful when:
-                      </p>
-
-                      <ul>
-
-                          <li>the application itself is (maybe partly) still 
using the Log4j 1.x API, or if
-                          </li>
-
-                          <li>the application depends on a library which 
depends on the Log 1.x API, or</li>
-
-                          <li>
-                              the application needs to support logging 
configurations in the old Log4j 1.x format.
-                          </li>
-                      </ul>
-
-                      <p>
-                          To use this option, applications need to use the 
following three jar files:
-                          the Log4j 2 API jar (log4j-api.jar),
-                          the Log4j 2 implementation jar (log4j-core.jar) and
-                          the Log4j 1.x bridge jar (log4j-1.2-api.jar).
-                      </p>
-
-                      <p><img src="../images/whichjar-log4j-1.2-api.png" 
alt="Using log4j 2 via the log4j 1.x API" /></p>
-
-                      <p>
-                          For most applications this is sufficient.
-                          This is a low-effort way to migrate, and may also 
allow for migration to proceed gradually over time.
-                      </p>
-
-                      <section>
-                          <h4><a 
name="Limitations_of_the_Log4j_1.x_bridge"></a>Limitations of the Log4j 1.x 
bridge</h4>
-
-                          <p>
-                              Applications can migrate by just using the 
bridge without further code changes,
-                              if they meet the following requirements:
-                          </p>
-
-                          <ol style="list-style-type: decimal">
-
-                              <li>They must not access methods and classes 
internal to the Log4j 1.x implementation such
-                                  as Appenders, LoggerRepository or Category's
-                                  callAppenders method.</li>
-
-                              <li>They must not programmatically configure 
Log4j.</li>
-
-                              <li>They must not configure by calling the Log4j 
1.x classes DOMConfigurator or
-                                  PropertyConfigurator.</li>
-                          </ol>
-
-                      </section><section>
-                      <h4><a 
name="When_to_stop_using_the_Log4j_1.x_bridge"></a>When to stop using the Log4j 
1.x bridge</h4>
-
-                      <p>
-                          Once you have migrated all of your own application 
and library code under your control, you may not need the bridge any more.
-                          Note that when you use a library/framework that can 
be configured to use several logging frameworks,
-                          then you typically don't need the log4j-1.2-api 
bridge either,
-                          as you may be able to directly configure it to use 
Log4j v2 instead v1.
-                          Some libraries/frameworks even auto-detect the 
presence of certain logging framework implementations on their classpath,
-                          and automagically switch their internal logging 
delegation accordingly;
-                          try simple removing the Log4j v1 dependency instead 
of replacing it with this bridge,
-                          and test if logging from all of your dependencies 
still work.
-                      </p>
-
-                      <p>
-                          If you own or can contribute open source to the 
library you depend on, consider replacing its use of the Log4j v1 API with the 
v2 API.
-                      </p>
-
-                      <p>
-                          While the Log4j 1.x bridge supports logging 
configurations that use the Log4j 1.x properties or XML format,
-                          migrating to the new 2.x format is not difficult.
-                          The Log4j 2 web site contains extensive 
documentation on the 2.x configuration format.
-                          Examples for migrating logging configurations from 
the v1 format to the v2 format are below.
-                      </p>
-                  </section></section>
-                  <section>
-                      <h3><a 
name="Option_2:_convert_your_application_to_the_Log4j_2_API_.28log4j-api.29"></a>Option
 2: convert your application to the Log4j 2 API (log4j-api)</h3>
-
-                      <p>
-                          The other migration option involves changing your 
application code to use
-                          the Log4j 2 API.
-                          For the most part, converting from the Log4j 1.x API 
to Log4j 2 should be fairly simple. Many
-                          of the log statements will require no modification. 
However, where necessary the following changes must be
-                          made.</p>
-
-                      <p><img src="../images/whichjar-log4j-api.png" 
alt="Using log4j 2 via the log4j 2.x API" /></p>
-
-                      <table border="0" class="table table-striped" 
width="100%">
-
-                          <tr class="a">
-
-                              <th>Log4j 1.x</th>
-
-                              <th>Log4j 2.x</th>
-                          </tr>
-
-                          <tr class="b">
-
-                              <td>Package name: org.apache.log4j</td>
-
-                              <td>org.apache.logging.log4j</td>
-                          </tr>
-
-                          <tr class="a">
-
-                              <td>Calls to 
org.apache.log4j.Logger.getLogger()</td>
-
-                              
<td>org.apache.logging.log4j.LogManager.getLogger()</td>
-                          </tr>
-
-                          <tr class="b">
-
-                              <td>Calls to 
org.apache.log4j.Logger.getRootLogger() or
-                                  
org.apache.log4j.LogManager.getRootLogger()</td>
-
-                              <td> 
org.apache.logging.log4j.LogManager.getRootLogger()</td>
-                          </tr>
-
-                          <tr class="a">
-
-                              <td>Calls to org.apache.log4j.Logger.getLogger 
that accept a LoggerFactory</td>
-
-                              <td> Remove the 
org.apache.log4j.spi.LoggerFactory and use one of Log4j 2's other extension
-                                  mechanisms</td>
-                          </tr>
-
-                          <tr class="b">
-
-                              <td>Calls to 
org.apache.log4j.Logger.getEffectiveLevel()</td>
-
-                              
<td>org.apache.logging.log4j.Logger.getLevel()</td>
-                          </tr>
-
-                          <tr class="a">
-
-                              <td>Calls to 
org.apache.log4j.LogManager.shutdown()</td>
-
-                              <td>Not needed in version 2
-                                  because the Log4j Core now automatically 
adds a JVM shutdown hook on start up to perform any Core
-                                  clean ups.
-
-                                  <ol style="list-style-type: decimal">
-
-                                      <li>
-                                          Starting in Log4j 2.1, you can 
specify a custom
-                                          <a 
href="../log4j-core/apidocs/org/apache/logging/log4j/core/util/ShutdownCallbackRegistry.html"
 class="javadoc">ShutdownCallbackRegistry</a>
-                                          to override the default JVM shutdown 
hook strategy.
-                                      </li>
-
-                                      <li>
-                                          Starting in Log4j 2.6, you can now 
use org.apache.logging.log4j.LogManager.shutdown()
-                                          to initiate shutdown manually.
-                                      </li>
-                                  </ol>
-                              </td>
-                          </tr>
-
-                          <tr class="b">
-
-                              <td>Calls to org.apache.log4j.Logger.setLevel() 
or similar methods
-                              </td>
-
-                              <td>Not supported at API level. Equivalent 
functionality is provided in the Log4j 2 implementation
-                                  classes, see 
org.apache.logging.log4j.core.config.Configurator.setLevel(), but may leave
-                                  the application susceptible to changes in 
Log4j 2 internals.</td>
-                          </tr>
-
-                          <tr class="a">
-
-                              <td>String concatenation like 
logger.info(&quot;hi &quot; + userName)</td>
-
-                              <td>Parameterized messages like 
logger.info(&quot;hi {}&quot;, userName)</td>
-                          </tr>
-
-                          <tr class="b">
-
-                              <td><a class="externalLink" 
href="http://logging.apache.org/log4j/1.2/apidocs/org/apache/log4j/MDC.html";>org.apache.log4j.MDC</a>
 and
-                                  <a class="externalLink" 
href="http://logging.apache.org/log4j/1.2/apidocs/org/apache/log4j/NDC.html";>org.apache.log4j.NDC</a>
-                              </td>
-
-                              <td><a href="thread-context.html">Thread 
Context</a></td>
-                          </tr>
-                      </table>
-                  </section>
-                  <section>
-                      <h3><a 
name="Migrating_logging_configurations_to_the_Log4j_2_format"></a>Migrating 
logging configurations to the Log4j 2 format</h3>
-
-                      <p>
-                          Although the Log4j 2 configuration syntax is 
different than that of Log4j 1.x, most, if not all, of
-                          the same functionality is available.
-                      </p>
-                      <section>
-                          <h4><a name="Interpolation"></a>Interpolation</h4>
-
-                          <p>
-                              Note that system property interpolation via the 
${foo} syntax has been extended to allow
-                              property lookups from many different sources. 
See the <a href="lookups.html">Lookups</a> documentation
-                              for more details. For example, using a lookup 
for the system property named catalina.base,
-                              in Log4j 1.x, the syntax would be 
${catalina.base}. In Log4j 2, the syntax would be
-                              ${sys:catalina.base}.
-                          </p>
-                      </section><section>
-                      <h4><a name="Layouts"></a>Layouts</h4>
-
-                      <p>
-                          Log4j 1.x has a XMLLayout which is different from 
the XmlLayout in Log4j 2. The log4j-1.2-api module
-                          contains a Log4j1XmlLayout that produces output in 
the Log4j 1.x format.
-                      </p>
-
-                      <p>
-                          The Log4j 1.x SimpleLayout can be emulated with 
PatternLayout &quot;%level - %m%n&quot;.
-                      </p>
-
-                      <p>
-                          The Log4j 1.x TTCCLayout can be emulated with 
PatternLayout &quot;%r [%t] %p %c %notEmpty{%ndc }- %m%n&quot;.
-                      </p>
-
-                      <p>
-                          Both PatternLayout and EnhancedPatternLayout in 
Log4j 1.x can be replaced with
-                          PatternLayout in Log4j 2. The log4j-1.2-api module 
contains two pattern conversions &quot;%ndc&quot; and &quot;%properties&quot; 
which
-                          can be used to emulate &quot;%x&quot; and 
&quot;%X&quot; in Log4j 1.x PatternLayout (&quot;%x&quot; and %X&quot; in Log4j 
2 have a slightly different format).
-                      </p>
-
-                      <p>
-                          Below are some example configurations for Log4j 1.x 
and their counterparts in Log4j 2.
-                      </p>
-
-                  </section><section>
-                      <h4><a 
name="Sample_1_-_Migrating_a_simple_Console_Appender_configuration"></a>Sample 
1 - Migrating a simple Console Appender configuration</h4>
-
-                      <p>Log4j 1.x XML configuration</p>
-
-                      <div>
-<pre class="prettyprint linenums">&lt;?xml version=&quot;1.0&quot; 
encoding=&quot;UTF-8&quot;?&gt;
-&lt;!DOCTYPE log4j:configuration PUBLIC &quot;-//APACHE//DTD LOG4J 
1.2//EN&quot; &quot;log4j.dtd&quot;&gt;
+        <div class="row-fluid">
+            <header id="leftColumn" class="span2">
+                <nav class="well sidebar-nav">
+                    <ul class="nav nav-list">
+                        <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/home.png" alt="Apache Log4j™ 2" border="0"/> Apache 
Log4j™ 2</li>
+                        <li><a href="../index.html" title="About"><span 
class="none"></span>About</a></li>
+                        <li><a href="../download.html" title="Download"><span 
class="none"></span>Download</a></li>
+                        <li><a href="../javadoc.html" title="Javadoc"><span 
class="icon-chevron-right"></span>Javadoc</a></li>
+                        <li><a href="../maven-artifacts.html" title="Maven, 
Ivy, Gradle Artifacts"><span class="icon-chevron-right"></span>Maven, Ivy, 
Gradle Artifacts</a></li>
+                        <li><a href="../runtime-dependencies.html" 
title="Runtime Dependencies"><span class="none"></span>Runtime 
Dependencies</a></li>
+                        <li><a href="../changelog.html" 
title="Changelog"><span class="none"></span>Changelog</a></li>
+                        <li><a href="../faq.html" title="FAQ"><span 
class="none"></span>FAQ</a></li>
+                        <li><a href="../performance.html" 
title="Performance"><span class="icon-chevron-right"></span>Performance</a></li>
+                        <li><a href="../articles.html" title="Articles and 
Tutorials"><span class="none"></span>Articles and Tutorials</a></li>
+                        <li><a href="../security.html" title="Security"><span 
class="none"></span>Security</a></li>
+                        <li><a href="../support.html" title="Support"><span 
class="none"></span>Support</a></li>
+                        <li><a href="../thanks.html" title="Thanks"><span 
class="none"></span>Thanks</a></li>
+                        <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/pencil.png" alt="For Contributors" border="0"/> For 
Contributors</li>
+                        <li><a href="../build.html" title="Building Log4j from 
Source"><span class="none"></span>Building Log4j from Source</a></li>
+                        <li><a href="../guidelines.html" 
title="Guidelines"><span class="none"></span>Guidelines</a></li>
+                        <li><a href="../javastyle.html" title="Style 
Guide"><span class="none"></span>Style Guide</a></li>
+                        <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/book.png" alt="Manual" border="0"/> Manual</li>
+                        <li><a href="../manual/index.html" 
title="Introduction"><span class="none"></span>Introduction</a></li>
+                        <li><a href="../manual/architecture.html" 
title="Architecture"><span class="none"></span>Architecture</a></li>
+                        <li class="active"><a href="#"><span 
class="icon-chevron-down"></span>Log4j 1.x Migration</a>
+                            <ul class="nav nav-list">
+                                <li><a 
href="../manual/migration.html#Log4j1.2Bridge" title="Log4j 1.x Bridge"><span 
class="none"></span>Log4j 1.x Bridge</a></li>
+                                <li><a 
href="../manual/migration.html#EnablingLog4j1.2Bridge" title="Enabling the 
Bridge"><span class="none"></span>Enabling the Bridge</a></li>
+                                <li><a 
href="../manual/migration.html#APICompatibility" title="API 
Compatibility"><span class="none"></span>API Compatibility</a></li>
+                                <li><a 
href="../manual/migration.html#ConfigurationCompatibility" title="Configuration 
Compatibility"><span class="none"></span>Configuration Compatibility</a></li>
+                                <li><a 
href="../manual/migration.html#Log4j1.2BridgeLimitations" title="Bridge 
Limitations"><span class="none"></span>Bridge Limitations</a></li>
+                                <li><a 
href="../manual/migration.html#Log4j2API" title="Migrating to the Log4j 2 
API"><span class="none"></span>Migrating to the Log4j 2 API</a></li>
+                                <li><a 
href="../manual/migration.html#Log4j2ConfigurationFormat" title="Migrating to 
the Log4j 2 Configuration"><span class="none"></span>Migrating to the Log4j 2 
Configuration</a></li>
+                            </ul></li>
+                        <li><a href="../manual/api.html" title="Java 
API"><span class="icon-chevron-right"></span>Java API</a></li>
+                        <li><a href="../manual/scala-api.html" title="Scala 
API"><span class="none"></span>Scala API</a></li>
+                        <li><a href="../manual/configuration.html" 
title="Configuration"><span 
class="icon-chevron-right"></span>Configuration</a></li>
+                        <li><a href="../manual/usage.html" title="Usage"><span 
class="icon-chevron-right"></span>Usage</a></li>
+                        <li><a href="../manual/webapp.html" title="Web 
Applications and JSPs"><span class="icon-chevron-right"></span>Web Applications 
and JSPs</a></li>
+                        <li><a href="../manual/lookups.html" 
title="Lookups"><span class="icon-chevron-right"></span>Lookups</a></li>
+                        <li><a href="../manual/appenders.html" 
title="Appenders"><span class="icon-chevron-right"></span>Appenders</a></li>
+                        <li><a href="../manual/layouts.html" 
title="Layouts"><span class="icon-chevron-right"></span>Layouts</a></li>
+                        <li><a href="../manual/filters.html" 
title="Filters"><span class="icon-chevron-right"></span>Filters</a></li>
+                        <li><a href="../manual/async.html" title="Async 
Loggers"><span class="icon-chevron-right"></span>Async Loggers</a></li>
+                        <li><a href="../manual/garbagefree.html" 
title="Garbage-free Logging"><span 
class="icon-chevron-right"></span>Garbage-free Logging</a></li>
+                        <li><a href="../manual/jmx.html" title="JMX"><span 
class="none"></span>JMX</a></li>
+                        <li><a href="../manual/logsep.html" title="Logging 
Separation"><span class="none"></span>Logging Separation</a></li>
+                        <li><a href="../manual/extending.html" 
title="Extending Log4j"><span class="icon-chevron-right"></span>Extending 
Log4j</a></li>
+                        <li><a href="../manual/plugins.html" 
title="Plugins"><span class="icon-chevron-right"></span>Plugins</a></li>
+                        <li><a href="../manual/customconfig.html" 
title="Programmatic Log4j Configuration"><span 
class="icon-chevron-right"></span>Programmatic Log4j Configuration</a></li>
+                        <li><a href="../manual/customloglevels.html" 
title="Custom Log Levels"><span class="icon-chevron-right"></span>Custom Log 
Levels</a></li>
+                        <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/tag.png" alt="Related Projects" border="0"/> Related 
Projects</li>
+                        <li><a 
href="http://logging.apache.org/log4j/scala/index.html"; class="externalLink" 
title="Log4j-Scala"><span class="none"></span>Log4j-Scala</a></li>
+                        <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/link.png" alt="Legacy Sites" border="0"/> Legacy 
Sites</li>
+                        <li><a href="http://logging.apache.org/log4j/1.2/"; 
class="externalLink" title="Log4j 1.2 - End of Life"><span 
class="none"></span>Log4j 1.2 - End of Life</a></li>
+                        <li><a 
href="http://logging.apache.org/log4j/log4j-2.3.1/"; class="externalLink" 
title="Log4j 2.3.1 - Java 6"><span class="none"></span>Log4j 2.3.1 - Java 
6</a></li>
+                        <li><a 
href="http://logging.apache.org/log4j/log4j-2.12.3/"; class="externalLink" 
title="Log4j 2.12.3 - Java 7"><span class="none"></span>Log4j 2.12.3 - Java 
7</a></li>
+                        <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/cog.png" alt="Components" border="0"/> Components</li>
+                        <li><a href="../log4j-api/index.html" 
title="API"><span class="none"></span>API</a></li>
+                        <li><a href="../log4j-core/index.html" 
title="Implementation"><span class="none"></span>Implementation</a></li>
+                        <li><a href="../log4j-jcl/index.html" title="Commons 
Logging Bridge"><span class="none"></span>Commons Logging Bridge</a></li>
+                        <li><a href="../log4j-1.2-api/index.html" title="Log4j 
1.2 API"><span class="none"></span>Log4j 1.2 API</a></li>
+                        <li><a href="../log4j-slf4j-impl/index.html" 
title="SLF4J Binding"><span class="none"></span>SLF4J Binding</a></li>
+                        <li><a href="../log4j-jul/index.html" title="JUL 
Adapter"><span class="none"></span>JUL Adapter</a></li>
+                        <li><a href="../log4j-jpl/index.html" title="JDK 
Platform Logger"><span class="none"></span>JDK Platform Logger</a></li>
+                        <li><a href="../log4j-to-slf4j/index.html" 
title="Log4j 2 to SLF4J Adapter"><span class="none"></span>Log4j 2 to SLF4J 
Adapter</a></li>
+                        <li><a href="../log4j-flume-ng/index.html" 
title="Apache Flume Appender"><span class="none"></span>Apache Flume 
Appender</a></li>
+                        <li><a href="../log4j-taglib/index.html" title="Log4j 
Tag Library"><span class="none"></span>Log4j Tag Library</a></li>
+                        <li><a href="../log4j-jmx-gui/index.html" title="Log4j 
JMX GUI"><span class="none"></span>Log4j JMX GUI</a></li>
+                        <li><a href="../log4j-web/index.html" title="Log4j Web 
Application Support"><span class="none"></span>Log4j Web Application 
Support</a></li>
+                        <li><a href="../log4j-jakarta-web/index.html" 
title="Log4j Jakarta Web Application Support"><span class="none"></span>Log4j 
Jakarta Web Application Support</a></li>
+                        <li><a href="../log4j-appserver/index.html" 
title="Log4j Application Server Integration"><span class="none"></span>Log4j 
Application Server Integration</a></li>
+                        <li><a href="../log4j-couchdb/index.html" title="Log4j 
CouchDB appender"><span class="none"></span>Log4j CouchDB appender</a></li>
+                        <li><a href="../log4j-mongodb3/index.html" 
title="Log4j MongoDB3 appender"><span class="none"></span>Log4j MongoDB3 
appender</a></li>
+                        <li><a href="../log4j-mongodb4/index.html" 
title="Log4j MongoDB4 appender"><span class="none"></span>Log4j MongoDB4 
appender</a></li>
+                        <li><a href="../log4j-cassandra/index.html" 
title="Log4j Cassandra appender"><span class="none"></span>Log4j Cassandra 
appender</a></li>
+                        <li><a href="../log4j-iostreams/index.html" 
title="Log4j IO Streams"><span class="none"></span>Log4j IO Streams</a></li>
+                        <li><a href="../log4j-liquibase/index.html" 
title="Log4j Liquibase Binding"><span class="none"></span>Log4j Liquibase 
Binding</a></li>
+                        <li><a href="../log4j-docker/index.html" title="Log4j 
Docker Support"><span class="none"></span>Log4j Docker Support</a></li>
+                        <li><a href="../log4j-spring-boot/index.html" 
title="Log4j Spring Boot"><span class="none"></span>Log4j Spring Boot</a></li>
+                        <li><a 
href="../log4j-spring-cloud-config/log4j-spring-cloud-config-client/index.html" 
title="Log4j Spring Cloud Config Client"><span class="none"></span>Log4j Spring 
Cloud Config Client</a></li>
+                        <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/info.png" alt="Project Information" border="0"/> Project 
Information</li>
+                        <li><a href="../dependency-convergence.html" 
title="Dependency Convergence"><span class="none"></span>Dependency 
Convergence</a></li>
+                        <li><a href="../dependency-management.html" 
title="Dependency Management"><span class="none"></span>Dependency 
Management</a></li>
+                        <li><a href="../team-list.html" title="Project 
Team"><span class="none"></span>Project Team</a></li>
+                        <li><a href="../mail-lists.html" title="Mailing 
Lists"><span class="none"></span>Mailing Lists</a></li>
+                        <li><a href="../issue-tracking.html" title="Issue 
Tracking"><span class="none"></span>Issue Tracking</a></li>
+                        <li><a href="../license.html" title="Project 
License"><span class="none"></span>Project License</a></li>
+                        <li><a href="../source-repository.html" title="Source 
Repository"><span class="none"></span>Source Repository</a></li>
+                        <li><a href="../project-summary.html" title="Project 
Summary"><span class="none"></span>Project Summary</a></li>
+                        <li class="nav-header"><img class="imageLink" 
src="../img/glyphicons/layers.png" alt="Project Reports" border="0"/> Project 
Reports</li>
+                        <li><a href="../changes-report.html" title="Changes 
Report"><span class="none"></span>Changes Report</a></li>
+                        <li><a href="../jira-report.html" title="JIRA 
Report"><span class="none"></span>JIRA Report</a></li>
+                        <li><a href="../rat-report.html" title="RAT 
Report"><span class="none"></span>RAT Report</a></li>
+                    </ul>
+                </nav>
+                <div class="well sidebar-nav">
+                    <hr />
+                    <div id="poweredBy">
+                        <div class="clear"></div>
+                        <div class="clear"></div>
+                        <div class="clear"></div>
+                        <a href="http://maven.apache.org/"; title="Built by 
Maven" class="poweredBy"><img class="builtBy" alt="Built by Maven" 
src="../images/logos/maven-feather.png" /></a>
+                    </div>
+                </div>
+            </header>
+            <main id="bodyColumn"  class="span10" >
+                <!-- vim: set syn=markdown : -->
+                <!--
+                 Licensed to the Apache Software Foundation (ASF) under one or 
more
+                 contributor license agreements. See the NOTICE file 
distributed with
+                 this work for additional information regarding copyright 
ownership.
+                 The ASF licenses this file to You under the Apache License, 
Version 2.0
+                 (the "License"); you may not use this file except in 
compliance with
+                 the License. You may obtain a copy of the License at
+
+                         http://www.apache.org/licenses/LICENSE-2.0
+
+                 Unless required by applicable law or agreed to in writing, 
software
+                 distributed under the License is distributed on an "AS IS" 
BASIS,
+                 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express 
or implied.
+                 See the License for the specific language governing 
permissions and
+                 limitations under the License.
+                -->
+                <section>
+                    <h2><a 
name="Migrating_from_Log4j_1.x_to_2.x"></a>Migrating from Log4j 1.x to 2.x</h2>
+                    <p>This page explains how to migrate applications or 
libraries currently using the Log4j 1.x API to use Log4j v2 as their main 
logging framework.</p>
+                    <p><a name="Log4j1.2Bridge"></a></p><section>
+                    <h3><a 
name="Option_1:_use_the_Log4j_1.x_bridge_.28log4j-1.2-api.29"></a>Option 1: use 
the Log4j 1.x bridge (log4j-1.2-api)</h3>
+                    <p>You may be able to convert an application to Log4j 2 
<i>without any code changes</i> by replacing the Log4j 1.x jar file with Log4j 
2&#x2019;s log4j-1.2-api.jar.</p>
+                    <p>The Log4j 1.x bridge is useful when:</p>
+                    <ul>
+
+                        <li>the application itself is (maybe partly) still 
using the Log4j 1.x API, or if</li>
+                        <li>the application depends on a library which depends 
on the Log 1.x API, or</li>
+                        <li>the application needs to support logging 
configurations in the old Log4j 1.x format.</li>
+                    </ul>
+                    <p>To use this option, applications need to use the 
following three jar files: the Log4j 2 API jar (log4j-api.jar), the Log4j 2 
implementation jar (log4j-core.jar) and the Log4j 1.x bridge jar 
(log4j-1.2-api.jar).</p>
+                    <p><img src="../images/whichjar-log4j-1.2-api.png" 
alt="Using log4j 2 via the log4j 1.x API" /></p>
+                    <p>For most applications this is sufficient. This is a 
low-effort way to migrate, and may also allow for migration to proceed 
gradually over time.</p>
+                    <p><a name="EnablingLog4j1.2Bridge"></a></p><section>
+                    <h4><a name="Enabling_the_Log4j_1.x_bridge"></a>Enabling 
the Log4j 1.x bridge</h4>
+                    <p>Enable the Log4j 1.x bridge via one of the following 
steps:</p>
+                    <ol style="list-style-type: decimal">
+
+                        <li>Set the system property 
&#x201c;log4j1.compatibility&#x201d; to a value of &#x201c;true&#x201d;. Log4j 
2 will then add log4j.properties, log4j-test.properties, log4j.xml and 
log4j-test.xml to the <a 
href="configuration.html#AutomaticConfiguration">configuration files</a> it 
searches for on the class path.</li>
+                        <li>Set the Log4j 1 system property 
&#x201c;log4j.configuration&#x201d; to the location of the log4j 1 
configuration file. The files must have a file extension of either 
&#x201c;.properties&#x201d; or &#x201c;.xml&#x201d;.</li>
+                    </ol>
+                    <p><a name="APICompatibility"></a></p></section><section>
+                    <h4><a name="API_Compatibility"></a>API Compatibility</h4>
+                    <p>Log4j 2 provides support for the Log4j 1 logging 
methods by providing alternate implementations of the classes containing those 
methods. These classes may be found in the log4j-1.2-api jar distributed with 
the project. All calls to perform logging will result in the data passed to the 
logging methods to be forwarded to the Log4j2 API where they can be processed 
by implementations of the Log4j 2 API.</p>
+                    <p><a 
name="ConfigurationCompatibility"></a></p></section><section>
+                    <h4><a 
name="Configuration_Compatibility"></a>Configuration Compatibility</h4>
+                    <p>Log4j 2 provides support for Log4j 1 configuration 
files. Configuration of the Appenders, Layouts and Filters that were provided 
in the Log4j 1 distribution will be redirected to their Log4j 2 counterparts - 
with the exception of the implemented Rewrite Policies. This means that 
although the behavior of these components will be similar, they may not be 
exactly the same. For example, the XML generated by the XMLLayout may not 
exactly match the XML generated by the L [...]
+                    <p>In addition, Log4j 2 supports custom Log4j 1 Appenders, 
Filters, and Layouts with some constraints. Since the original Log4j 1 
components may not be present in Log4j 2, custom components that extend them 
will fail.</p><section>
+                    <h5><a name="Supported_Components"></a>Supported 
Components</h5>
+                    <p>Supported Appenders include: AsyncAppender, 
ConsoleAppender, DailyRollingFileAppender, FileAppender, NullAppender, 
RewriteAppender (limited), RollingFileAppender, SyslogAppender.</p>
+                    <p>Supported Filters include: DenyAllFilter, 
LevelMatchFilter, LevelRangeFilter, StringMatchFilter.</p>
+                    <p>Supported Layouts include: HtmlLayout, PatternLayout, 
SimpleLayout, TTCCLayout , XmlLayout.</p>
+                    <p>Supported Rewrite Policies include: MapRewritePolicy, 
PropertyRewritePolicy.</p></section><section>
+                    <h5><a 
name="Unsupported_or_Unimplemented_Components"></a>Unsupported or Unimplemented 
Components</h5>
+                    <p>If your configuration contains any of the below 
components, consider <a 
href="migration.html#Log4j2ConfigurationFormat">migrating your 
configuration</a> to the Log4j 2 format.</p><section>
+                    <h6><a name="Appenders"></a>Appenders</h6>
+                    <ul>
+
+                        <li>JDBCAppender (cannot be mapped to Log4j 2&#x2019;s 
JdbcAppender)</li>
+                        <li>JMSAppender</li>
+                        <li>SMTPAppender</li>
+                        <li>SocketAppender (Requires the use of the 
SerializedLayout which is a security risk)</li>
+                        <li>SocketHubAppender (Requires the use of the 
SerializedLayout which is a securiy risk)</li>
+                        <li>TelnetAppender (Security risk)</li>
+                    </ul></section><section>
+                    <h6><a name="Rewrite_Policies"></a>Rewrite Policies</h6>
+                    <ul>
+
+                        <li>ReflectionRewritePolicy</li>
+                        <li>Custom rewrite policies since LoggingEvent is 
currently a no-op.</li>
+                    </ul></section><section>
+                    <h6><a name="Renderers"></a>Renderers</h6>
+                    <p>Log4j 2 currently ignores renderers.</p>
+                    <p><a 
name="Log4j1.2BridgeLimitations"></a></p></section></section></section><section>
+                    <h4><a 
name="Limitations_of_the_Log4j_1.x_bridge"></a>Limitations of the Log4j 1.x 
bridge</h4>
+                    <p>Applications can migrate by just using the bridge 
without further code changes, if they meet the following requirements:</p>
+                    <ol style="list-style-type: decimal">
+
+                        <li>They must not access methods and classes internal 
to the Log4j 1.x implementation such as Appenders, LoggerRepository or 
Category&#x2019;s callAppenders method.</li>
+                        <li>They must not programmatically configure 
Log4j.</li>
+                        <li>They must not configure by calling the Log4j 1.x 
classes DOMConfigurator or PropertyConfigurator.</li>
+                    </ol></section><section>
+                    <h4><a 
name="When_to_stop_using_the_Log4j_1.x_bridge"></a>When to stop using the Log4j 
1.x bridge</h4>
+                    <p>Once you have migrated all of your own application and 
library code under your control, you may not need the bridge any more. Note 
that when you use a library/framework that can be configured to use several 
logging frameworks, then you typically don&#x2019;t need the log4j-1.2-api 
bridge either, as you may be able to directly configure it to use Log4j v2 
instead v1. Some libraries/frameworks even auto-detect the presence of certain 
logging framework implementations [...]
+                    <p>If you own or can contribute open source to the library 
you depend on, consider replacing its use of the Log4j v1 API with the v2 
API.</p>
+                    <p>While the Log4j 1.x bridge supports logging 
configurations that use the Log4j 1.x properties or XML format, migrating to 
the new 2.x format is not difficult. The Log4j 2 web site contains extensive 
documentation on the 2.x configuration format. Examples for migrating logging 
configurations from the v1 format to the v2 format are below.</p>
+                    <p><a 
name="Log4j2API"></a></p></section></section><section>
+                    <h3><a 
name="Option_2:_convert_your_application_to_the_Log4j_2_API_.28log4j-api.29"></a>Option
 2: convert your application to the Log4j 2 API (log4j-api)</h3>
+                    <p>The other migration option involves changing your 
application code to use the Log4j 2 API. For the most part, converting from the 
Log4j 1.x API to Log4j 2 should be fairly simple. Many of the log statements 
will require no modification. However, where necessary the following changes 
must be made.</p>
+                    <p><img src="../images/whichjar-log4j-api.png" alt="Using 
log4j 2 via the log4j 2.x API" /></p>
+                    <table border="0" class="table table-striped">
+                        <thead>
+
+                        <tr class="a">
+                            <th> Log4j 1.x                       </th>
+                            <th> Log4j 2.x </th></tr>
+                        </thead><tbody>
+
+                    <tr class="b">
+                        <td>Package name: org.apache.log4j </td>
+                        <td> org.apache.logging.log4j </td></tr>
+                    <tr class="a">
+                        <td>Calls to org.apache.log4j.Logger.getLogger() </td>
+                        <td> org.apache.logging.log4j.LogManager.getLogger() 
</td></tr>
+                    <tr class="b">
+                        <td>Calls to org.apache.log4j.Logger.getRootLogger() 
or org.apache.log4j.LogManager.getRootLogger() </td>
+                        <td> 
org.apache.logging.log4j.LogManager.getRootLogger() </td></tr>
+                    <tr class="a">
+                        <td>Calls to org.apache.log4j.Logger.getLogger that 
accept a LoggerFactory </td>
+                        <td> Remove the org.apache.log4j.spi.LoggerFactory and 
use one of Log4j 2&#x2019;s other extension mechanisms </td></tr>
+                    <tr class="b">
+                        <td>Calls to 
org.apache.log4j.Logger.getEffectiveLevel() </td>
+                        <td> org.apache.logging.log4j.Logger.getLevel() 
</td></tr>
+                    <tr class="a">
+                        <td>Calls to org.apache.log4j.LogManager.shutdown() 
</td>
+                        <td> Not needed in version 2 because the Log4j Core 
now automatically adds a JVM shutdown hook on start up to perform any Core 
clean ups. Starting in Log4j 2.1, you can specify a custom <a 
href="../log4j-core/apidocs/org/apache/logging/log4j/core/util/ShutdownCallbackRegistry.html">ShutdownCallbackRegistry</a>
 to override the default JVM shutdown hook strategy. Starting in Log4j 2.6, you 
can use org.apache.logging.log4j.LogManager.shutdown()  to initiate shutdown  
[...]
+                    <tr class="b">
+                        <td>Calls to org.apache.log4j.Logger.setLevel() or 
similar methods </td>
+                        <td> Not supported at API level. Equivalent 
functionality is provided in the Log4j 2 implementation classes, see 
org.apache.logging.log4j.core.config.Configurator.setLevel(), but this may 
leave the application susceptible to changes in Log4j 2 internals. </td></tr>
+                    <tr class="a">
+                        <td>String concatenation like logger.info(&quot;hi 
&quot; + userName) </td>
+                        <td> Parameterized messages like logger.info(&quot;hi 
{}&quot;, userName) </td></tr>
+                    <tr class="b">
+                        <td> <a class="externalLink" 
href="http://logging.apache.org/log4j/1.2/apidocs/org/apache/log4j/MDC.html";>org.apache.log4j.MDC</a>
 and <a class="externalLink" 
href="http://logging.apache.org/log4j/1.2/apidocs/org/apache/log4j/NDC.html";>org.apache.log4j.NDC</a>
 </td>
+                        <td> <a href="thread-context.html">Thread Context</a> 
</td></tr>
+                    </tbody>
+                    </table>
+                    <p><a 
name="Log4j2ConfigurationFormat"></a></p></section><section>
+                    <h3><a 
name="Migrating_logging_configurations_to_the_Log4j_2_format"></a>Migrating 
logging configurations to the Log4j 2 format</h3>
+                    <p>Although the Log4j 2 configuration syntax is different 
from that of Log4j 1.x, most, if not all, of the same functionality is 
available.</p><section>
+                    <h4><a name="Interpolation"></a>Interpolation</h4>
+                    <p>Note that system property interpolation via the ${foo} 
syntax has been extended to allow property lookups from many different sources. 
See the <a href="lookups.html">Lookups</a> documentation for more details. For 
example, using a lookup for the system property named catalina.base, in Log4j 
1.x, the syntax would be ${catalina.base}. In Log4j 2, the syntax would be 
${sys:catalina.base}.</p></section><section>
+                    <h4><a name="Layouts"></a>Layouts</h4>
+                    <p>Log4j 1.x has a XMLLayout which is different from the 
XmlLayout in Log4j 2. The log4j-1.2-api module contains a Log4j1XmlLayout that 
produces output in the Log4j 1.x format.</p>
+                    <p>The Log4j 1.x SimpleLayout can be emulated with 
PatternLayout &#x201c;%level - %m%n&#x201d;.</p>
+                    <p>The Log4j 1.x TTCCLayout can be emulated with 
PatternLayout &#x201c;%r [%t] %p %c %notEmpty{%ndc }- %m%n&#x201d;.</p>
+                    <p>Both PatternLayout and EnhancedPatternLayout in Log4j 
1.x can be replaced with PatternLayout in Log4j 2. The log4j-1.2-api module 
contains two pattern conversions &#x201c;%ndc&#x201d; and 
&#x201c;%properties&#x201d; which can be used to emulate &#x201c;%x&#x201d; and 
&#x201c;%X&#x201d; in Log4j 1.x PatternLayout (&#x201c;%x&#x201d; and %X&quot; 
in Log4j 2 have a slightly different format).</p>
+                    <p>Below are some example configurations for Log4j 1.x and 
their counterparts in Log4j 2.</p></section><section>
+                    <h4><a 
name="Sample_1_-_Migrating_a_simple_Console_Appender_configuration"></a>Sample 
1 - Migrating a simple Console Appender configuration</h4>
+                    <p>Log4j 1.x XML configuration</p>
+
+                    <div>
+                        <div>
+<pre class="source">&lt;!DOCTYPE log4j:configuration PUBLIC 
&quot;-//APACHE//DTD LOG4J 1.2//EN&quot; &quot;log4j.dtd&quot;&gt;
 &lt;log4j:configuration xmlns:log4j='http://jakarta.apache.org/log4j/'&gt;
   &lt;appender name=&quot;STDOUT&quot; 
class=&quot;org.apache.log4j.ConsoleAppender&quot;&gt;
     &lt;layout class=&quot;org.apache.log4j.PatternLayout&quot;&gt;
@@ -407,13 +305,14 @@
     &lt;priority value =&quot;debug&quot; /&gt;
     &lt;appender-ref ref=&quot;STDOUT&quot; /&gt;
   &lt;/Root&gt;
-&lt;/log4j:configuration&gt;</pre></div>
+&lt;/log4j:configuration&gt;
+</pre></div></div>
 
-                      <p>Log4j 2 XML configuration</p>
+                    <p>Log4j 2 XML configuration</p>
 
-                      <div>
-<pre class="prettyprint linenums">&lt;?xml version=&quot;1.0&quot; 
encoding=&quot;UTF-8&quot;?&gt;
-&lt;Configuration&gt;
+                    <div>
+                        <div>
+<pre class="source">&lt;Configuration&gt;
   &lt;Appenders&gt;
     &lt;Console name=&quot;STDOUT&quot; target=&quot;SYSTEM_OUT&quot;&gt;
       &lt;PatternLayout pattern=&quot;%d %-5p [%t] %C{2} (%F:%L) - 
%m%n&quot;/&gt;
@@ -425,16 +324,15 @@
       &lt;AppenderRef ref=&quot;STDOUT&quot;/&gt;
     &lt;/Root&gt;
   &lt;/Loggers&gt;
-&lt;/Configuration&gt;</pre></div>
-
-                  </section><section>
-                      <h4><a 
name="Sample_2_-_Migrating_a_simple_File_Appender.2C_XMLLayout_and_SimpleLayout_configuration"></a>Sample
 2 - Migrating a simple File Appender, XMLLayout and SimpleLayout 
configuration</h4>
-
-                      <p>Log4j 1.x XML configuration</p>
-
-                      <div>
-<pre class="prettyprint linenums">&lt;?xml version=&quot;1.0&quot; 
encoding=&quot;UTF-8&quot;?&gt;
-&lt;!DOCTYPE log4j:configuration PUBLIC &quot;-//APACHE//DTD LOG4J 
1.2//EN&quot; &quot;log4j.dtd&quot;&gt;
+&lt;/Configuration&gt;
+</pre></div></div>
+                </section><section>
+                    <h4><a 
name="Sample_2_-_Migrating_a_simple_File_Appender.2C_XMLLayout_and_SimpleLayout_configuration"></a>Sample
 2 - Migrating a simple File Appender, XMLLayout and SimpleLayout 
configuration</h4>
+                    <p>Log4j 1.x XML configuration</p>
+
+                    <div>
+                        <div>
+<pre class="source">&lt;!DOCTYPE log4j:configuration PUBLIC 
&quot;-//APACHE//DTD LOG4J 1.2//EN&quot; &quot;log4j.dtd&quot;&gt;
 &lt;log4j:configuration 
xmlns:log4j=&quot;http://jakarta.apache.org/log4j/&quot;&gt;
   &lt;appender name=&quot;A1&quot; 
class=&quot;org.apache.log4j.FileAppender&quot;&gt;
     &lt;param name=&quot;File&quot;   value=&quot;A1.log&quot; /&gt;
@@ -452,14 +350,14 @@
     &lt;priority value =&quot;debug&quot; /&gt;
     &lt;appender-ref ref=&quot;STDOUT&quot; /&gt;
   &lt;/Root&gt;
-&lt;/log4j:configuration&gt;</pre></div>
-
+&lt;/log4j:configuration&gt;
+</pre></div></div>
 
-                      <p>Log4j 2 XML configuration</p>
+                    <p>Log4j 2 XML configuration</p>
 
-                      <div>
-<pre class="prettyprint linenums">&lt;?xml version=&quot;1.0&quot; 
encoding=&quot;UTF-8&quot;?&gt;
-&lt;Configuration&gt;
+                    <div>
+                        <div>
+<pre class="source">&lt;Configuration&gt;
   &lt;Appenders&gt;
     &lt;File name=&quot;A1&quot; fileName=&quot;A1.log&quot; 
append=&quot;false&quot;&gt;
       &lt;Log4j1XmlLayout /&gt;
@@ -476,17 +374,15 @@
       &lt;AppenderRef ref=&quot;STDOUT&quot;/&gt;
     &lt;/Root&gt;
   &lt;/Loggers&gt;
-&lt;/Configuration&gt;</pre></div>
-
-                  </section><section>
-                      <h4><a 
name="Sample_3_-_Migrating_a_SocketAppender_configuration"></a>Sample 3 - 
Migrating a SocketAppender configuration</h4>
-
-                      <p>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.</p>
-
-                      <div>
-<pre class="prettyprint linenums">&lt;?xml version=&quot;1.0&quot; 
encoding=&quot;UTF-8&quot;?&gt;
-&lt;!DOCTYPE log4j:configuration PUBLIC &quot;-//APACHE//DTD LOG4J 
1.2//EN&quot; &quot;log4j.dtd&quot;&gt;
+&lt;/Configuration&gt;
+</pre></div></div>
+                </section><section>
+                    <h4><a 
name="Sample_3_-_Migrating_a_SocketAppender_configuration"></a>Sample 3 - 
Migrating a SocketAppender configuration</h4>
+                    <p>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.</p>
+
+                    <div>
+                        <div>
+<pre class="source">&lt;!DOCTYPE log4j:configuration PUBLIC 
&quot;-//APACHE//DTD LOG4J 1.2//EN&quot; &quot;log4j.dtd&quot;&gt;
 &lt;log4j:configuration 
xmlns:log4j=&quot;http://jakarta.apache.org/log4j/&quot;&gt;
   &lt;appender name=&quot;A1&quot; 
class=&quot;org.apache.log4j.net.SocketAppender&quot;&gt;
     &lt;param name=&quot;RemoteHost&quot; value=&quot;localhost&quot;/&gt;
@@ -509,14 +405,14 @@
     &lt;priority value=&quot;debug&quot;/&gt;
     &lt;appender-ref ref=&quot;STDOUT&quot;/&gt;
   &lt;/Root&gt;
-&lt;/log4j:configuration&gt;</pre></div>
+&lt;/log4j:configuration&gt;
+</pre></div></div>
 
+                    <p>Log4j 2 XML configuration</p>
 
-                      <p>Log4j 2 XML configuration</p>
-
-                      <div>
-<pre class="prettyprint linenums">&lt;?xml version=&quot;1.0&quot; 
encoding=&quot;UTF-8&quot;?&gt;
-&lt;Configuration&gt;
+                    <div>
+                        <div>
+<pre class="source">&lt;Configuration&gt;
   &lt;Appenders&gt;
     &lt;Socket name=&quot;A1&quot; host=&quot;localHost&quot; 
port=&quot;5000&quot;&gt;
       &lt;PatternLayout pattern=&quot;%t %-5p %c{2} - %m%n&quot;/&gt;
@@ -533,16 +429,15 @@
       &lt;AppenderRef ref=&quot;STDOUT&quot;/&gt;
     &lt;/Root&gt;
   &lt;/Loggers&gt;
-&lt;/Configuration&gt;</pre></div>
-
-                  </section><section>
-                      <h4><a 
name="Sample_4_-_Migrating_an_AsyncAppender_and_TTCCLayout_configuration"></a>Sample
 4 - Migrating an AsyncAppender and TTCCLayout configuration</h4>
-
-                      <p>Log4j 1.x XML configuration using the 
AsyncAppender.</p>
-
-                      <div>
-<pre class="prettyprint linenums">&lt;?xml version=&quot;1.0&quot; 
encoding=&quot;UTF-8&quot;?&gt;
-&lt;!DOCTYPE log4j:configuration PUBLIC &quot;-//APACHE//DTD LOG4J 
1.2//EN&quot; &quot;log4j.dtd&quot;&gt;
+&lt;/Configuration&gt;
+</pre></div></div>
+                </section><section>
+                    <h4><a 
name="Sample_4_-_Migrating_an_AsyncAppender_and_TTCCLayout_configuration"></a>Sample
 4 - Migrating an AsyncAppender and TTCCLayout configuration</h4>
+                    <p>Log4j 1.x XML configuration using the AsyncAppender.</p>
+
+                    <div>
+                        <div>
+<pre class="source">&lt;!DOCTYPE log4j:configuration PUBLIC 
&quot;-//APACHE//DTD LOG4J 1.2//EN&quot; &quot;log4j.dtd&quot;&gt;
 &lt;log4j:configuration 
xmlns:log4j=&quot;http://jakarta.apache.org/log4j/&quot; 
configDebug=&quot;true&quot;&gt;
   &lt;appender name=&quot;ASYNC&quot; 
class=&quot;org.apache.log4j.AsyncAppender&quot;&gt;
     &lt;appender-ref ref=&quot;TEMP&quot;/&gt;
@@ -559,14 +454,14 @@
     &lt;priority value=&quot;debug&quot;/&gt;
     &lt;appender-ref ref=&quot;ASYNC&quot;/&gt;
   &lt;/Root&gt;
-&lt;/log4j:configuration&gt;</pre></div>
-
+&lt;/log4j:configuration&gt;
+</pre></div></div>
 
-                      <p>Log4j 2 XML configuration. </p>
+                    <p>Log4j 2 XML configuration.</p>
 
-                      <div>
-<pre class="prettyprint linenums">&lt;?xml version=&quot;1.0&quot; 
encoding=&quot;UTF-8&quot;?&gt;
-&lt;Configuration status=&quot;debug&quot;&gt;
+                    <div>
+                        <div>
+<pre class="source">&lt;Configuration status=&quot;debug&quot;&gt;
   &lt;Appenders&gt;
     &lt;File name=&quot;TEMP&quot; fileName=&quot;temp&quot;&gt;
       &lt;PatternLayout pattern=&quot;%r [%t] %p %c %notEmpty{%ndc }- 
%m%n&quot;/&gt;
@@ -580,17 +475,15 @@
       &lt;AppenderRef ref=&quot;ASYNC&quot;/&gt;
     &lt;/Root&gt;
   &lt;/Loggers&gt;
-&lt;/Configuration&gt;</pre></div>
-
-
-                  </section><section>
-                      <h4><a 
name="Sample_5_-_Migrating_a_configuration_using_AsyncAppender_with_Console_and_File"></a>Sample
 5 - Migrating a configuration using AsyncAppender with Console and File</h4>
-
-                      <p>Log4j 1.x XML configuration using the 
AsyncAppender.</p>
-
-                      <div>
-<pre class="prettyprint linenums">&lt;?xml version=&quot;1.0&quot; 
encoding=&quot;UTF-8&quot;?&gt;
-&lt;!DOCTYPE log4j:configuration PUBLIC &quot;-//APACHE//DTD LOG4J 
1.2//EN&quot; &quot;log4j.dtd&quot;&gt;
+&lt;/Configuration&gt;
+</pre></div></div>
+                </section><section>
+                    <h4><a 
name="Sample_5_-_Migrating_a_configuration_using_AsyncAppender_with_Console_and_File"></a>Sample
 5 - Migrating a configuration using AsyncAppender with Console and File</h4>
+                    <p>Log4j 1.x XML configuration using the AsyncAppender.</p>
+
+                    <div>
+                        <div>
+<pre class="source">&lt;!DOCTYPE log4j:configuration PUBLIC 
&quot;-//APACHE//DTD LOG4J 1.2//EN&quot; &quot;log4j.dtd&quot;&gt;
 &lt;log4j:configuration 
xmlns:log4j=&quot;http://jakarta.apache.org/log4j/&quot; 
configDebug=&quot;true&quot;&gt;
   &lt;appender name=&quot;ASYNC&quot; 
class=&quot;org.apache.log4j.AsyncAppender&quot;&gt;
     &lt;appender-ref ref=&quot;TEMP&quot;/&gt;
@@ -611,15 +504,14 @@
     &lt;priority value=&quot;debug&quot;/&gt;
     &lt;appender-ref ref=&quot;ASYNC&quot;/&gt;
   &lt;/Root&gt;
-&lt;/log4j:configuration&gt;</pre></div>
+&lt;/log4j:configuration&gt;
+</pre></div></div>
 
+                    <p>Log4j 2 XML configuration. Note that the Async Appender 
should be configured after the appenders it references. This will allow it to 
shut down properly.</p>
 
-                      <p>Log4j 2 XML configuration. Note that the Async 
Appender should be configured after the appenders it
-                          references. This will allow it to shutdown 
properly.</p>
-
-                      <div>
-<pre class="prettyprint linenums">&lt;?xml version=&quot;1.0&quot; 
encoding=&quot;UTF-8&quot;?&gt;
-&lt;Configuration status=&quot;debug&quot;&gt;
+                    <div>
+                        <div>
+<pre class="source">&lt;Configuration status=&quot;debug&quot;&gt;
   &lt;Appenders&gt;
     &lt;Console name=&quot;CONSOLE&quot; target=&quot;SYSTEM_OUT&quot;&gt;
       &lt;PatternLayout pattern=&quot;%d %-5p [%t] %C{2} (%F:%L) - 
%m%n&quot;/&gt;
@@ -637,25 +529,19 @@
       &lt;AppenderRef ref=&quot;ASYNC&quot;/&gt;
     &lt;/Root&gt;
   &lt;/Loggers&gt;
-&lt;/Configuration&gt;</pre></div>
-                  </section></section>
-              </section>
-
-
-          </main>
-
-
-
-      </div>
+&lt;/Configuration&gt;
+</pre></div></div></section></section></section>
+            </main>
+        </div>
     </div>
     <hr/>
     <footer>
-      <div class="container-fluid">
-        <div class="row-fluid">
-<p align="center">Copyright &copy; 1999-2021 <a class="external" 
href="http://www.apache.org";>The Apache Software Foundation</a>. All Rights 
Reserved.<br>
-      Apache Logging, Apache Log4j, Log4j, Apache, the Apache feather logo, 
and the Apache Logging project logo are trademarks of The Apache Software 
Foundation.</p>
+        <div class="container-fluid">
+            <div class="row-fluid">
+                <p align="center">Copyright &copy; 1999-2021 <a 
class="external" href="http://www.apache.org";>The Apache Software 
Foundation</a>. All Rights Reserved.<br>
+                    Apache Logging, Apache Log4j, Log4j, Apache, the Apache 
feather logo, and the Apache Logging project logo are trademarks of The Apache 
Software Foundation.</p>
+            </div>
         </div>
-      </div>
     </footer>
   </body>
 </html>

Reply via email to