blob: f38e6f3c4d41827696e9f91a839dfd6bc6cf23dc [file] [log] [blame]
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<!--
| Generated by Apache Maven Doxia at Jun 9, 2012
| Rendered using Apache Maven Fluido Skin
-->
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>
Log4j 2 Lookups</title>
<link rel="stylesheet" href="../css/apache-maven-fluido.min.css" />
<link rel="stylesheet" href="../css/site.css" />
<link rel="stylesheet" href="../css/print.css" media="print" />
<script type="text/javascript" src="../js/apache-maven-fluido.min.js"></script>
<meta name="author" content="Ralph Goers" />
<meta name="Date-Revision-yyyymmdd" content="20120609" />
<meta http-equiv="Content-Language" content="en" />
</head>
<body class="topBarDisabled">
<div class="container-fluid">
<div id="banner">
<div class="pull-left">
<a href="../../../" id="bannerLeft">
<img src="../images/ls-logo.jpg" alt="Apache Logging Services™"/>
</a>
</div>
<div class="pull-right"> <div id="bannerRight">
<img src="../images/logo.jpg" />
</div>
</div>
<div class="clear"><hr/></div>
</div>
<div id="breadcrumbs">
<ul class="breadcrumb">
<li id="publishDate">Last Published: 2012-06-09</li>
<li class="divider">|</li> <li id="projectVersion">Version: 2.0-alpha1-SNAPSHOT</li>
<li class="pull-right"> <a href="http://wiki.apache.org/logging" class="externalLink" title="Logging Wiki">Logging Wiki</a>
</li>
<li class="divider pull-right">|</li>
<li class="pull-right"> <a href="http://www.apache.org/" class="externalLink" title="Apache">Apache</a>
</li>
<li class="divider pull-right">|</li>
<li class="pull-right"> <a href="../../../" title="Logging Services">Logging Services</a>
</li>
<li class="divider pull-right">|</li>
<li class="pull-right"> <a href="../../" title="Log4j">Log4j</a>
</li>
<li class="divider pull-right">|</li>
<li class="pull-right"> <a href="../../companions" title="Log4j Companions">Log4j Companions</a>
</li>
</ul>
</div>
<div class="row-fluid">
<div id="leftColumn" class="span3">
<div class="well sidebar-nav">
<h3>Apache Log4j™ 2</h3>
<ul>
<li class="none">
<a href="../index.html" title="About">About</a>
</li>
<li class="none">
<a href="../download.html" title="Download">Download</a>
</li>
<li class="none">
<a href="../build.html" title="Build and Install">Build and Install</a>
</li>
<li class="none">
<a href="../changelog.html" title="Changelog">Changelog</a>
</li>
</ul>
<h3>Manual</h3>
<ul>
<li class="none">
<a href="../manual/index.html" title="Introduction">Introduction</a>
</li>
<li class="none">
<a href="../manual/architecture.html" title="Architecture">Architecture</a>
</li>
<li class="collapsed">
<a href="../manual/api.html" title="API">API</a>
</li>
<li class="collapsed">
<a href="../manual/configuration.html" title="Configuration">Configuration</a>
</li>
<li class="collapsed">
<a href="../manual/plugins.html" title="Plugins">Plugins</a>
</li>
<li class="expanded">
<strong>Lookups</strong>
<ul>
<li class="none">
<a href="../manual/lookups.html#ContextMapLookup" title="ContextMap">ContextMap</a>
</li>
<li class="none">
<a href="../manual/lookups.html#DateLookcup" title="Date">Date</a>
</li>
<li class="none">
<a href="../manual/lookups.html#EnvironmentLookup" title="Environment">Environment</a>
</li>
<li class="none">
<a href="../manual/lookups.html#MapLookup" title="Map">Map</a>
</li>
<li class="none">
<a href="../manual/lookups.html#StructuredDataLookup" title="StructuredData">StructuredData</a>
</li>
<li class="none">
<a href="../manual/lookups.html#SystemPropertiesLookup" title="SystemProperties">SystemProperties</a>
</li>
</ul>
</li>
<li class="collapsed">
<a href="../manual/appenders.html" title="Appenders">Appenders</a>
</li>
<li class="collapsed">
<a href="../manual/layouts.html" title="Layouts">Layouts</a>
</li>
<li class="collapsed">
<a href="../manual/filters.html" title="Filters">Filters</a>
</li>
<li class="none">
<a href="../manual/jmx.html" title="JMX">JMX</a>
</li>
<li class="none">
<a href="../manual/logsep.html" title="Logging Separation">Logging Separation</a>
</li>
<li class="collapsed">
<a href="../manual/extending.html" title="Extending Log4j">Extending Log4j</a>
</li>
</ul>
<h3>Logging Adapters</h3>
<ul>
<li class="none">
<a href="../log4j12-api/api.html" title="Log4j 1.x API">Log4j 1.x API</a>
</li>
<li class="none">
<a href="../log4j2-jcl/api.html" title="Commons Logging">Commons Logging</a>
</li>
<li class="none">
<a href="../slf4j-impl/api.html" title="SLF4J">SLF4J</a>
</li>
</ul>
<h3>Components</h3>
<ul>
<li class="none">
<a href="../log4j-api/index.html" title="API">API</a>
</li>
<li class="none">
<a href="../log4j-core/index.html" title="Impl">Impl</a>
</li>
<li class="none">
<a href="../log4j12-api/index.html" title="Log4J 1.2 API">Log4J 1.2 API</a>
</li>
<li class="none">
<a href="../log4j-jcl/index.html" title="Commons Logging Bridge">Commons Logging Bridge</a>
</li>
<li class="none">
<a href="../slf4j-impl/index.html" title="SLF4J Binding">SLF4J Binding</a>
</li>
<li class="none">
<a href="../log4j-flume-og/index.html" title="Flume OG">Flume OG</a>
</li>
<li class="none">
<a href="../log4j-flume-ng/index.html" title="Flume NG">Flume NG</a>
</li>
</ul>
<h3>Project Documentation</h3>
<ul>
<li class="collapsed">
<a href="../project-info.html" title="Project Information">Project Information</a>
</li>
<li class="collapsed">
<a href="../project-reports.html" title="Project Reports">Project Reports</a>
</li>
</ul>
<hr class="divider" />
<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="poweredBy" alt="Built by Maven" src="../images/logos/maven-feather.png" />
</a>
</div>
</div>
</div>
<div id="bodyColumn" class="span9" >
<!-- 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. -->
<div class="section"><h2>Lookups<a name="Lookups"></a></h2>
<p>
Lookups provide a way to add values to the Log4j configuration at arbitrary places. They are
a particular type of Plugin that implements the
<a href="../log4j2-core/apidocs/org/apache/logging/log4j/core/lookup/StrLookup.html">StrLookup</a> interface.
Information on how to use Lookups in configuration files can be found in the
<a href="./configuration.html#PropertySubstitution">Property Substitution</a> section of the
<a href="./configuration.html">Configuration</a> page.
</p>
<a name="ContextMapLookup"></a>
<div class="section"><h3>ContextMapLookup<a name="ContextMapLookup"></a></h3>
<p>
The ContextMapLookup allows applications to store data in the Log4j ThreadContext Map and
then retrieve the values in the Log4j configuration. In the example below, the application
would store the current user's login id in the ThreadContext Map with the key &quot;loginId&quot;. During
initial configuration processing the first '$' will be removed. The PatternLayout supports
interpolation with Lookups and will then resolve the variable for each event. Note that
the pattern &quot;%X{loginId}&quot; would achieve the same result.
</p>
<div class="source"><pre class="prettyprint"> &lt;File name=&quot;Application&quot; fileName=&quot;application.log&quot;&gt;
&lt;PatternLayout&gt;
&lt;pattern&gt;%d %p %C{1.} [%t] $${ctx:loginId} %m%n&lt;/pattern&gt;
&lt;/PatternLayout&gt;
&lt;/File&gt;</pre></div>
</div>
<a name="DateLookup"></a>
<div class="section"><h3>DateLookup<a name="DateLookup"></a></h3>
<p>
The DateLookup is somewhat unusual from the other lookups as it doesn't use the key to locate an item.
Instead, the key can be used to specify a date format string that is valid for
<a class="externalLink" href="http://docs.oracle.com/javase/6/docs/api/java/text/SimpleDateFormat.html">SimpleDateFormat</a>.
The current date, or the date associated with the current log event will be formatted as specified.
</p>
<div class="source"><pre class="prettyprint"> &lt;RollingFile name=&quot;Rolling-${map:type}&quot; fileName=&quot;${filename}&quot;
filePattern=&quot;target/rolling1/test1-$${date:MM-dd-yyyy}.%i.log.gz&quot;&gt;
&lt;PatternLayout&gt;
&lt;pattern&gt;%d %p %C{1.} [%t] %m%n&lt;/pattern&gt;
&lt;/PatternLayout&gt;
&lt;SizeBasedTriggeringPolicy size=&quot;500&quot; /&gt;
&lt;/RollingFile&gt;</pre></div>
</div>
<a name="EnvironmentLookup"></a>
<div class="section"><h3>EnvironmentLookup<a name="EnvironmentLookup"></a></h3>
<p>
The EnvironmentLookup allows systems to configure environment variables, either in global files
such as /etc/profile or in the startup scripts for applications, and then retrieve those variables
from within the logging configuration. The example below includes the name of the currently logged
in user in the application log.
</p>
<div class="source"><pre class="prettyprint"> &lt;File name=&quot;Application&quot; fileName=&quot;application.log&quot;&gt;
&lt;PatternLayout&gt;
&lt;pattern&gt;%d %p %C{1.} [%t] $${env:USER} %m%n&lt;/pattern&gt;
&lt;/PatternLayout&gt;
&lt;/File&gt;</pre></div>
</div>
<a name="MapLookup"></a>
<div class="section"><h3>MapLookup<a name="MapLookup"></a></h3>
<p>
The MapLookup serves two purposes.
</p><ol style="list-style-type: decimal">
<li>Provide the base for Properties declared in the configuration file.</li>
<li>Retrieve values from MapMessages in LogEvents.</li>
</ol>
The first item simply means that the MapLookup is used to substitute properties that are defined
in the configuration file. These variables are specified without a prefix - e.g. <tt>${name}</tt>.
The second usage allows a value from the current
<a href="../log4j2-api/apidocs/org/apache/logging/log4j/message/MapMessage.html">MapMessage</a>,
if one is part of the current log event, to be substituted. In the example below the RoutingAppender will
use a different RollingFileAppender for each unique value of the key named &quot;type&quot; in the MapMessage. Note
that when used this way a value for &quot;type&quot; should be declared in the properties declaration to provide
a default value in case the message is not a MapMessage or the MapMessage does not contain the key. See the
<a href="./configuration.html#PropertySubstitution">Property Substitution</a> section of the
<a href="./configuration.html">Configuration</a> page for information on how to set the default values.
<div class="source"><pre class="prettyprint"> &lt;Routing name=&quot;Routing&quot;&gt;
&lt;Routes pattern=&quot;$${map:type}&quot;&gt;
&lt;Route&gt;
&lt;RollingFile name=&quot;Rolling-${map:type}&quot; fileName=&quot;${filename}&quot;
filePattern=&quot;target/rolling1/test1-${map:type}.%i.log.gz&quot;&gt;
&lt;PatternLayout&gt;
&lt;pattern&gt;%d %p %C{1.} [%t] %m%n&lt;/pattern&gt;
&lt;/PatternLayout&gt;
&lt;SizeBasedTriggeringPolicy size=&quot;500&quot; /&gt;
&lt;/RollingFile&gt;
&lt;/Route&gt;
&lt;/Routes&gt;
&lt;/Routing&gt;
</pre></div>
</div>
<a name="StructuredDataLookup"></a>
<div class="section"><h3>StructuredDataLookup<a name="StructuredDataLookup"></a></h3>
<p>
The StructuredDataLookup is very similar to the MapLookup in that it will retrieve values from
StructuredDataMessages. In addition to the Map values it will also return the name portion of the
id (not including the enterprise number) and the type field. The main difference between the
example below and the example for MapMessage is that the &quot;type&quot; is an attribute of the
<a href="../log4j2-api/apidocs/org/apache/logging/log4j/message/StructuredDataMessage.html">StructuredDataMessage</a>
while &quot;type&quot; would have to be an item in the Map in a MapMessage.
</p>
<div class="source"><pre class="prettyprint"> &lt;Routing name=&quot;Routing&quot;&gt;
&lt;Routes pattern=&quot;$${sd:type}&quot;&gt;
&lt;Route&gt;
&lt;RollingFile name=&quot;Rolling-${sd:type}&quot; fileName=&quot;${filename}&quot;
filePattern=&quot;target/rolling1/test1-${sd:type}.%i.log.gz&quot;&gt;
&lt;PatternLayout&gt;
&lt;pattern&gt;%d %p %C{1.} [%t] %m%n&lt;/pattern&gt;
&lt;/PatternLayout&gt;
&lt;SizeBasedTriggeringPolicy size=&quot;500&quot; /&gt;
&lt;/RollingFile&gt;
&lt;/Route&gt;
&lt;/Routes&gt;
&lt;/Routing&gt;
</pre></div>
</div>
<a name="SystemPropertiesLookup"></a>
<div class="section"><h3>SystemPropertiesLookup<a name="SystemPropertiesLookup"></a></h3>
<p>
As it is quite common to define values inside and outside the application by using System Properties,
it is only natural that they should be accessible via a Lookup. As system properties are often
defined outside the application it would be quite common to see something like:
</p>
<div class="source"><pre class="prettyprint"> &lt;appenders&gt;
&lt;File name=&quot;ApplicationLog&quot; fileName=&quot;${sys:logPath}/app.log&quot;/&gt;
&lt;/appenders&gt;</pre></div>
</div>
</div>
</div>
</div>
<hr/>
<footer>
<div class="container-fluid">
<div class="row span16">Copyright &copy; 1999-2012
<a href="http://www.apache.org">Apache Software Foundation</a>.
All Rights Reserved.
</div>
</div>
</footer>
</body>
</html>