CHARMS1
asked on
Using multiple appenders in log4J
I am using more than one log4j appender in the application that i am working on.
Is it possible to have a different logging level for each appender. ie: one appender picks up all logging and the other picks up only logging warnings and above.
Also is it possible to assign individual appenders to pick up logging from specific classes.
Thanks,
Mark
Is it possible to have a different logging level for each appender. ie: one appender picks up all logging and the other picks up only logging warnings and above.
Also is it possible to assign individual appenders to pick up logging from specific classes.
Thanks,
Mark
ASKER CERTIFIED SOLUTION
membership
This solution is only available to members.
To access this solution, you must be a member of Experts Exchange.
Why do you reask the same question
https://www.experts-exchange.com/questions/21865198/Log4J-question.html
Here is the log4j.xml of JBOSS (J2EE Application Server), you can see that it has many appender:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<!-- ========================== ========== ========== ========== ========== === -->
<!-- -->
<!-- Log4j Configuration -->
<!-- -->
<!-- ========================== ========== ========== ========== ========== === -->
<!-- $Id: log4j.xml,v 1.13.2.8 2003/09/23 14:16:27 slaboure Exp $ -->
<!--
| For more configuration infromation and examples see the Jakarta Log4j
| owebsite: http://jakarta.apache.org/log4j
-->
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/" debug="false">
<!-- ========================== ======= -->
<!-- Preserve messages in a local file -->
<!-- ========================== ======= -->
<!-- A time/date based rolling appender -->
<appender name="FILE" class="org.jboss.logging.a ppender.Da ilyRolling FileAppend er">
<errorHandler class="org.jboss.logging.u til.OnlyOn ceErrorHan dler"/>
<param name="File" value="${jboss.server.home .dir}/log/ server.log "/>
<param name="Append" value="false"/>
<!-- Rollover at midnight each day -->
<param name="DatePattern" value="'.'yyyy-MM-dd"/>
<!-- Rollover at the top of each hour
<param name="DatePattern" value="'.'yyyy-MM-dd-HH"/>
-->
<layout class="org.apache.log4j.Pa tternLayou t">
<!-- The default pattern: Date Priority [Category] Message\n -->
<param name="ConversionPattern" value="%d %-5p [%c] %m%n"/>
<!-- The full pattern: Date MS Priority [Category] (Thread:NDC) Message\n
<param name="ConversionPattern" value="%d %-5r %-5p [%c] (%t:%x) %m%n"/>
-->
</layout>
</appender>
<!-- A size based file rolling appender
<appender name="FILE" class="org.jboss.logging.a ppender.Ro llingFileA ppender">
<errorHandler class="org.jboss.logging.u til.OnlyOn ceErrorHan dler"/>
<param name="File" value="${jboss.server.home .dir}/log/ server.log "/>
<param name="Append" value="false"/>
<param name="MaxFileSize" value="500KB"/>
<param name="MaxBackupIndex" value="1"/>
<layout class="org.apache.log4j.Pa tternLayou t">
<param name="ConversionPattern" value="%d %-5p [%c] %m%n"/>
</layout>
</appender>
-->
<!-- ========================== ==== -->
<!-- Append messages to the console -->
<!-- ========================== ==== -->
<appender name="CONSOLE" class="org.apache.log4j.Co nsoleAppen der">
<errorHandler class="org.jboss.logging.u til.OnlyOn ceErrorHan dler"/>
<param name="Target" value="System.out"/>
<param name="Threshold" value="INFO"/>
<layout class="org.apache.log4j.Pa tternLayou t">
<!-- The default pattern: Date Priority [Category] Message\n -->
<param name="ConversionPattern" value="%d{ABSOLUTE} %-5p [%c{1}] %m%n"/>
</layout>
</appender>
<appender name="JSR77" class="org.apache.log4j.Fi leAppender ">
<errorHandler class="org.jboss.logging.u til.OnlyOn ceErrorHan dler"/>
<param name="Append" value="false"/>
<param name="File" value="${jboss.server.home .dir}/log/ jsr77.log" />
<layout class="org.apache.log4j.Pa tternLayou t">
<param name="ConversionPattern" value="%d{ABSOLUTE} %-5p [%c{1}] %m%n"/>
</layout>
</appender>
<!-- ====================== -->
<!-- More Appender examples -->
<!-- ====================== -->
<!-- Buffer events and log them asynchronously
<appender name="ASYNC" class="org.apache.log4j.As yncAppende r">
<errorHandler class="org.jboss.logging.u til.OnlyOn ceErrorHan dler"/>
<appender-ref ref="FILE"/>
<appender-ref ref="CONSOLE"/>
<appender-ref ref="SMTP"/>
</appender>
-->
<!-- EMail events to an administrator
<appender name="SMTP" class="org.apache.log4j.ne t.SMTPAppe nder">
<errorHandler class="org.jboss.logging.u til.OnlyOn ceErrorHan dler"/>
<param name="Threshold" value="ERROR"/>
<param name="To" value="admin@myhost.domain .com"/>
<param name="From" value="nobody@myhost.domai n.com"/>
<param name="Subject" value="JBoss Sever Errors"/>
<param name="SMTPHost" value="localhost"/>
<param name="BufferSize" value="10"/>
<layout class="org.apache.log4j.Pa tternLayou t">
<param name="ConversionPattern" value="[%d{ABSOLUTE},%c{1} ] %m%n"/>
</layout>
</appender>
-->
<!-- Syslog events
<appender name="SYSLOG" class="org.apache.log4j.ne t.SyslogAp pender">
<errorHandler class="org.jboss.logging.u til.OnlyOn ceErrorHan dler"/>
<param name="Facility" value="LOCAL7"/>
<param name="FacilityPrinting" value="true"/>
<param name="SyslogHost" value="localhost"/>
</appender>
-->
<!-- Log events to JMS (requires a topic to be created)
<appender name="JMS" class="org.apache.log4j.ne t.JMSAppen der">
<errorHandler class="org.jboss.logging.u til.OnlyOn ceErrorHan dler"/>
<param name="Threshold" value="ERROR"/>
<param name="TopicConnectionFacto ryBindingN ame" value="java:/ConnectionFac tory"/>
<param name="TopicBindingName" value="topic/MyErrorsTopic "/>
</appender>
-->
<!-- Log events through SNMP
<appender name="TRAP_LOG" class="org.apache.log4j.ex t.SNMPTrap Appender">
<errorHandler class="org.jboss.logging.u til.OnlyOn ceErrorHan dler"/>
<param name="ImplementationClassN ame" value="org.apache.log4j.ex t.JoeSNMPT rapSender" />
<param name="ManagementHost" value="127.0.0.1"/>
<param name="ManagementHostTrapLi stenPort" value="162"/>
<param name="EnterpriseOID" value="1.3.6.1.4.1.24.0"/>
<param name="LocalIPAddress" value="127.0.0.1"/>
<param name="LocalTrapSendPort" value="161"/>
<param name="GenericTrapType" value="6"/>
<param name="SpecificTrapType" value="12345678"/>
<param name="CommunityString" value="public"/>
<param name="ForwardStackTraceWit hTrap" value="true"/>
<param name="Threshold" value="DEBUG"/>
<param name="ApplicationTrapOID" value="1.3.6.1.4.1.24.12.1 0.22.64"/>
<layout class="org.apache.log4j.Pa tternLayou t">
<param name="ConversionPattern" value="%d,%p,[%t],[%c],%m% n"/>
</layout>
</appender>
-->
<!-- ================ -->
<!-- Limit categories -->
<!-- ================ -->
<!-- Limit the org.apache.commons category to INFO as its DEBUG is verbose -->
<category name="org.apache.commons">
<priority value="INFO"/>
</category>
<!-- Limit JBoss categories to INFO -->
<category name="org.jboss">
<priority value="INFO"/>
</category>
<!-- Decrease the priority threshold for the org.jboss.varia category
<category name="org.jboss.varia">
<priority value="DEBUG"/>
</category>
-->
<!-- Show the evolution of the DataSource pool in the logs [inUse/Available/Max]
<category name="org.jboss.resource.c onnectionm anager.JBo ssManagedC onnectionP ool">
<priority value="TRACE" class="org.jboss.logging.X Level"/>
</category>
-->
<!--
| An example of enabling the custom TRACE level priority that is used
| by the JBoss internals to diagnose low level details. This example
| turns on TRACE level msgs for the org.jboss.ejb.plugins package and its
| subpackages. This will produce A LOT of logging output.
<category name="org.jboss.system">
<priority value="TRACE" class="org.jboss.logging.X Level"/>
</category>
<category name="org.jboss.ejb.plugin s">
<priority value="TRACE" class="org.jboss.logging.X Level"/>
</category>
-->
<!--
| Logs these events to SNMP:
- server starts/stops
- cluster evolution (node death/startup)
- When an EJB archive is deployed (and associated verified messages)
- When an EAR archive is deployed
<category name="org.jboss.system.ser ver.Server ">
<priority value="INFO" />
<appender-ref ref="TRAP_LOG"/>
</category>
<category name="org.jboss.ha.framewo rk.interfa ces.HAPart ition.life cycle">
<priority value="INFO" />
<appender-ref ref="TRAP_LOG"/>
</category>
<category name="org.jboss.deployment .MainDeplo yer">
<priority value="ERROR" />
<appender-ref ref="TRAP_LOG"/>
</category>
<category name="org.jboss.ejb.EJBDep loyer">
<priority value="INFO" />
<appender-ref ref="TRAP_LOG"/>
</category>
<category name="org.jboss.deployment .EARDeploy er">
<priority value="INFO" />
<appender-ref ref="TRAP_LOG"/>
</category>
-->
<!-- ======================= -->
<!-- Setup the Root category -->
<!-- ======================= -->
<root>
<appender-ref ref="CONSOLE"/>
<appender-ref ref="FILE"/>
</root>
<!-- Clustering logging -->
<!-- Uncomment the following to redirect the org.jgroups and
org.jboss.ha categories to a cluster.log file.
<appender name="CLUSTER" class="org.jboss.logging.a ppender.Ro llingFileA ppender">
<errorHandler class="org.jboss.logging.u til.OnlyOn ceErrorHan dler"/>
<param name="File" value="${jboss.server.home .dir}/log/ cluster.lo g"/>
<param name="Append" value="false"/>
<param name="MaxFileSize" value="500KB"/>
<param name="MaxBackupIndex" value="1"/>
<layout class="org.apache.log4j.Pa tternLayou t">
<param name="ConversionPattern" value="%d %-5p [%c] %m%n"/>
</layout>
</appender>
<category name="org.jgroups">
<priority value="DEBUG" />
<appender-ref ref="CLUSTER"/>
</category>
<category name="org.jboss.ha">
<priority value="DEBUG" />
<appender-ref ref="CLUSTER"/>
</category>
-->
</log4j:configuration>
https://www.experts-exchange.com/questions/21865198/Log4J-question.html
Here is the log4j.xml of JBOSS (J2EE Application Server), you can see that it has many appender:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<!-- ==========================
<!-- -->
<!-- Log4j Configuration -->
<!-- -->
<!-- ==========================
<!-- $Id: log4j.xml,v 1.13.2.8 2003/09/23 14:16:27 slaboure Exp $ -->
<!--
| For more configuration infromation and examples see the Jakarta Log4j
| owebsite: http://jakarta.apache.org/log4j
-->
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/" debug="false">
<!-- ==========================
<!-- Preserve messages in a local file -->
<!-- ==========================
<!-- A time/date based rolling appender -->
<appender name="FILE" class="org.jboss.logging.a
<errorHandler class="org.jboss.logging.u
<param name="File" value="${jboss.server.home
<param name="Append" value="false"/>
<!-- Rollover at midnight each day -->
<param name="DatePattern" value="'.'yyyy-MM-dd"/>
<!-- Rollover at the top of each hour
<param name="DatePattern" value="'.'yyyy-MM-dd-HH"/>
-->
<layout class="org.apache.log4j.Pa
<!-- The default pattern: Date Priority [Category] Message\n -->
<param name="ConversionPattern" value="%d %-5p [%c] %m%n"/>
<!-- The full pattern: Date MS Priority [Category] (Thread:NDC) Message\n
<param name="ConversionPattern" value="%d %-5r %-5p [%c] (%t:%x) %m%n"/>
-->
</layout>
</appender>
<!-- A size based file rolling appender
<appender name="FILE" class="org.jboss.logging.a
<errorHandler class="org.jboss.logging.u
<param name="File" value="${jboss.server.home
<param name="Append" value="false"/>
<param name="MaxFileSize" value="500KB"/>
<param name="MaxBackupIndex" value="1"/>
<layout class="org.apache.log4j.Pa
<param name="ConversionPattern" value="%d %-5p [%c] %m%n"/>
</layout>
</appender>
-->
<!-- ==========================
<!-- Append messages to the console -->
<!-- ==========================
<appender name="CONSOLE" class="org.apache.log4j.Co
<errorHandler class="org.jboss.logging.u
<param name="Target" value="System.out"/>
<param name="Threshold" value="INFO"/>
<layout class="org.apache.log4j.Pa
<!-- The default pattern: Date Priority [Category] Message\n -->
<param name="ConversionPattern" value="%d{ABSOLUTE} %-5p [%c{1}] %m%n"/>
</layout>
</appender>
<appender name="JSR77" class="org.apache.log4j.Fi
<errorHandler class="org.jboss.logging.u
<param name="Append" value="false"/>
<param name="File" value="${jboss.server.home
<layout class="org.apache.log4j.Pa
<param name="ConversionPattern" value="%d{ABSOLUTE} %-5p [%c{1}] %m%n"/>
</layout>
</appender>
<!-- ====================== -->
<!-- More Appender examples -->
<!-- ====================== -->
<!-- Buffer events and log them asynchronously
<appender name="ASYNC" class="org.apache.log4j.As
<errorHandler class="org.jboss.logging.u
<appender-ref ref="FILE"/>
<appender-ref ref="CONSOLE"/>
<appender-ref ref="SMTP"/>
</appender>
-->
<!-- EMail events to an administrator
<appender name="SMTP" class="org.apache.log4j.ne
<errorHandler class="org.jboss.logging.u
<param name="Threshold" value="ERROR"/>
<param name="To" value="admin@myhost.domain
<param name="From" value="nobody@myhost.domai
<param name="Subject" value="JBoss Sever Errors"/>
<param name="SMTPHost" value="localhost"/>
<param name="BufferSize" value="10"/>
<layout class="org.apache.log4j.Pa
<param name="ConversionPattern" value="[%d{ABSOLUTE},%c{1}
</layout>
</appender>
-->
<!-- Syslog events
<appender name="SYSLOG" class="org.apache.log4j.ne
<errorHandler class="org.jboss.logging.u
<param name="Facility" value="LOCAL7"/>
<param name="FacilityPrinting" value="true"/>
<param name="SyslogHost" value="localhost"/>
</appender>
-->
<!-- Log events to JMS (requires a topic to be created)
<appender name="JMS" class="org.apache.log4j.ne
<errorHandler class="org.jboss.logging.u
<param name="Threshold" value="ERROR"/>
<param name="TopicConnectionFacto
<param name="TopicBindingName" value="topic/MyErrorsTopic
</appender>
-->
<!-- Log events through SNMP
<appender name="TRAP_LOG" class="org.apache.log4j.ex
<errorHandler class="org.jboss.logging.u
<param name="ImplementationClassN
<param name="ManagementHost" value="127.0.0.1"/>
<param name="ManagementHostTrapLi
<param name="EnterpriseOID" value="1.3.6.1.4.1.24.0"/>
<param name="LocalIPAddress" value="127.0.0.1"/>
<param name="LocalTrapSendPort" value="161"/>
<param name="GenericTrapType" value="6"/>
<param name="SpecificTrapType" value="12345678"/>
<param name="CommunityString" value="public"/>
<param name="ForwardStackTraceWit
<param name="Threshold" value="DEBUG"/>
<param name="ApplicationTrapOID" value="1.3.6.1.4.1.24.12.1
<layout class="org.apache.log4j.Pa
<param name="ConversionPattern" value="%d,%p,[%t],[%c],%m%
</layout>
</appender>
-->
<!-- ================ -->
<!-- Limit categories -->
<!-- ================ -->
<!-- Limit the org.apache.commons category to INFO as its DEBUG is verbose -->
<category name="org.apache.commons">
<priority value="INFO"/>
</category>
<!-- Limit JBoss categories to INFO -->
<category name="org.jboss">
<priority value="INFO"/>
</category>
<!-- Decrease the priority threshold for the org.jboss.varia category
<category name="org.jboss.varia">
<priority value="DEBUG"/>
</category>
-->
<!-- Show the evolution of the DataSource pool in the logs [inUse/Available/Max]
<category name="org.jboss.resource.c
<priority value="TRACE" class="org.jboss.logging.X
</category>
-->
<!--
| An example of enabling the custom TRACE level priority that is used
| by the JBoss internals to diagnose low level details. This example
| turns on TRACE level msgs for the org.jboss.ejb.plugins package and its
| subpackages. This will produce A LOT of logging output.
<category name="org.jboss.system">
<priority value="TRACE" class="org.jboss.logging.X
</category>
<category name="org.jboss.ejb.plugin
<priority value="TRACE" class="org.jboss.logging.X
</category>
-->
<!--
| Logs these events to SNMP:
- server starts/stops
- cluster evolution (node death/startup)
- When an EJB archive is deployed (and associated verified messages)
- When an EAR archive is deployed
<category name="org.jboss.system.ser
<priority value="INFO" />
<appender-ref ref="TRAP_LOG"/>
</category>
<category name="org.jboss.ha.framewo
<priority value="INFO" />
<appender-ref ref="TRAP_LOG"/>
</category>
<category name="org.jboss.deployment
<priority value="ERROR" />
<appender-ref ref="TRAP_LOG"/>
</category>
<category name="org.jboss.ejb.EJBDep
<priority value="INFO" />
<appender-ref ref="TRAP_LOG"/>
</category>
<category name="org.jboss.deployment
<priority value="INFO" />
<appender-ref ref="TRAP_LOG"/>
</category>
-->
<!-- ======================= -->
<!-- Setup the Root category -->
<!-- ======================= -->
<root>
<appender-ref ref="CONSOLE"/>
<appender-ref ref="FILE"/>
</root>
<!-- Clustering logging -->
<!-- Uncomment the following to redirect the org.jgroups and
org.jboss.ha categories to a cluster.log file.
<appender name="CLUSTER" class="org.jboss.logging.a
<errorHandler class="org.jboss.logging.u
<param name="File" value="${jboss.server.home
<param name="Append" value="false"/>
<param name="MaxFileSize" value="500KB"/>
<param name="MaxBackupIndex" value="1"/>
<layout class="org.apache.log4j.Pa
<param name="ConversionPattern" value="%d %-5p [%c] %m%n"/>
</layout>
</appender>
<category name="org.jgroups">
<priority value="DEBUG" />
<appender-ref ref="CLUSTER"/>
</category>
<category name="org.jboss.ha">
<priority value="DEBUG" />
<appender-ref ref="CLUSTER"/>
</category>
-->
</log4j:configuration>
Appenders are differenced by a name.
Use this to difference the things you want.
Bye, Giant.
Use this to difference the things you want.
Bye, Giant.
:-)
That is the same as what I hasd already posted, can you explain why you accepted only that comment please?
Yes, you would set the level in your logger, then attach that logger to you appender.
> Also is it possible to assign individual appenders to pick up logging from specific classes.
Yes define a logger for each class, and assign the required appender to that logger