【问题标题】:log4j appender threshold and categorylog4j appender 阈值和类别
【发布时间】:2009-06-24 23:54:23
【问题描述】:

让我先说我已经用尽了 Google,或者至少是我一直在尝试搜索的东西。 “log4j 阈值”、“log4j 阈值类别”、“log4j appender 阈值类别”等。但我真的不明白我从谷歌得到的结果。

这是我得到的完整配置。我不知道如何修改它以满足我的需要。

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">

<!-- ===================================================================== -->
<!--                                                                       -->
<!--  Log4j Configuration                                                  -->
<!--                                                                       -->
<!-- ===================================================================== -->

<!-- $Id: jboss-log4j.xml 62403 2007-04-18 15:26:43Z dimitris@jboss.org $ -->

<!--
| 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 -->
<!-- ================================= -->

<appender name="FILE" class="org.jboss.logging.appender.DailyRollingFileAppender">
  <errorHandler class="org.jboss.logging.util.OnlyOnceErrorHandler"/>
  <param name="File" value="${jboss.server.log.dir}/server.log"/>
  <param name="Append" value="false"/>

  <!-- Rollover at midnight each day -->
  <param name="DatePattern" value="'.'yyyy-MM-dd"/>

  <layout class="org.apache.log4j.PatternLayout">
     <param name="ConversionPattern" value="%d %-5p [%c] %m%n"/>
  </layout>
</appender>


<!-- ============================== -->
<!-- Append messages to the console -->
<!-- ============================== -->

<appender name="CONSOLE" class="org.apache.log4j.ConsoleAppender">
  <errorHandler class="org.jboss.logging.util.OnlyOnceErrorHandler"/>
  <param name="Target" value="System.out"/>
  <param name="Threshold" value="DEBUG"/>

  <layout class="org.apache.log4j.PatternLayout">
     <!-- The default pattern: Date Priority [Category] Message\n -->
     <param name="ConversionPattern" value="%d{ABSOLUTE} %-5p [%c] %m%n"/>
  </layout>
</appender>



<!-- ================ -->
<!-- Limit categories -->
<!-- ================ -->

<category name="com.arjuna">
  <priority value="FATAL"/>
</category>   

<category name="com.sun.facelets">
  <priority value="ERROR"/>
</category>   

 <category name="jacorb">
   <priority value="FATAL"/>
 </category>

<category name="javax.enterprise.resource">
  <priority value="WARNING"/>
 </category>  

 <category name="javax.enterprise.resource.webcontainer.jsf">
    <priority value="WARNING"/>
 </category>  

 <category name="org.apache">
    <priority value="FATAL"/>
 </category>

 <category name="org.hibernate">
    <priority value="FATAL"/>
 </category>   

 <category name="org.jboss">
    <priority value="INFO"/>
 </category>

<category name="org.jboss.ejb3.EJB3Deployer">
    <priority value="WARNING" />
</category>

<category name="org.jboss.ejb3.JmxKernelAbstraction">
    <priority value="WARNING" />
</category>

<category name="org.jboss.management">
   <priority value="FATAL"/>
</category>

<category name="org.jboss.serial">
  <priority value="FATAL"/>
</category>

<category name="org.jboss.wsf.framework">
   <priority value="FATAL"/>
</category>   

<category name="org.jgroups">
   <priority value="FATAL"/>
</category>

<category name="org.quartz">
    <priority value="FATAL" />
</category>
<!-- ======================= -->
<!-- Setup the Root category -->
<!-- ======================= -->

<root>
   <appender-ref ref="CONSOLE"/>
   <appender-ref ref="FILE"/>
</root>



</log4j:configuration>

我不明白附加程序的“阈值”级别如何与类别交互。看,我只希望 com.foo.bar 消息显示在控制台上。但似乎我得到的远不止这些,例如,org.jboss.wsf.framework 正在转储 DEBUG 消息,即使我有一个名称与之匹配并设置为 FATAL 的类别。

我确定我正在操作正确的配置文件,因为 jboss 报告它在我更改配置后重新加载配置。那么如何正确设置类别/阈值级别?阈值和类别有什么区别?

示例输出(截断)。当我将石英设置为 FATAL 时,为什么它会出现在控制台上?

2009-06-22 00:58:37,666 INFO  [org.quartz.plugins.history.LoggingJobHistoryPlugin] Job JobInitializationPlugin.JobInitializationPlugin_jobInitializer execution complete at  00:58:37 06/22/2009 and reports: null
2009-06-22 01:08:37,669 DEBUG [org.quartz.simpl.SimpleJobFactory] Producing instance of Job 'JobInitializationPlugin.JobInitializationPlugin_jobInitializer', class=org.quartz.jobs.FileScanJob
2009-06-23 15:44:17,790 INFO  [org.jboss.wsf.stack.jbws.NativeServerConfig] 3.0.5.GA
2009-06-23 15:44:17,868 DEBUG [org.jboss.wsf.framework.deployment.DeploymentAspectManagerImpl] setDeploymentAspects on WSDeploymentAspectManagerEJB
2009-06-23 15:44:17,868 DEBUG [org.jboss.wsf.framework.deployment.DeploymentAspectManagerImpl] setDeploymentAspects on WSDeploymentAspectManagerEndpointAPI

【问题讨论】:

  • 能否展示真实的 log4j 文件(比如你如何设置 org.jboss.wsf 类别)和实际有问题的控制台输出?
  • 一晒:我更新了问题。

标签: configuration log4j


【解决方案1】:

要回答为什么 Quartz 会出现在日志中的具体问题,您必须按如下方式更改 Quartz 配置:

 <category name="org.quartz" additivity="false">
    <priority value="FATAL" />
 </category>

additivity 属性告诉 log4j 覆盖根设置并仅将其用于 org.quartz。

在以前版本的问题中,您说您只希望打开这些类中的那些消息,为此您必须首先将根元素中的优先级配置为致命(甚至否),然后它只会记录您明确打开的那些包/类。

要回答您关于阈值如何与类别交互的问题,基本上可以将其视为发布/订阅。类别设置 logger 发布的内容,阈值设置 appender 的订阅级别。

这有点复杂,因为类别不是一个单一的东西,而是一个层次结构,因此您在一个类别上设置发布级别这一事实并不是全部。它可能会在层次结构中被覆盖,就像您的情况一样。

【讨论】:

  • 我发现这个问题和答案非常混乱。我相信这个问题已经被编辑了几次,所以这个答案现在非常具有误导性。当然,如果我使用给定的 log4j xml,我确实不会得到任何 INFO 或 DEBUG Quartz 消息 - 它们仅限于 FATAL。注意:我在一个独立程序中测试了这个,而不是在 JBoss 中,所以我不知道 JBoss 是否对 log4j 做了一些聪明/不同的事情。
  • @davidfrancis,JBoss 可能将根级别设置为与您在独立设备中不同的东西。我认为问题和答案仍然有效。
  • 很公平,如果问题和答案被视为特定于 JBoss,那么我认为您是对的。问题是这个问题很笼统。让我很困惑,但这并不是什么新鲜事;]
【解决方案2】:

将“”从 移动到

即:

<category name="com.foo.bar">
  <priority value="DEBUG"/>
  <appender-ref ref="CONSOLE"/>
</category>   

<root>
  <appender-ref ref="FILE"/>
</root>

使用您显示的配置,控制台不应收到任何调试消息,因此请检查是否可以使用任何其他配置,或者是否某些代码正在以编程方式更改配置。

【讨论】:

  • 我用完整的配置和我正在谈论的一些示例输出更新了这个问题。
  • 仅仅因为 JBoss 重新加载它并不意味着它就是使用的。将 log4j 的根元素的 debug 设置为 true,输出可能会帮助您了解问题所在。
  • 谢谢...这个建议效果很好。从 标签中删除 appender 声明后,我的问题已解决。
猜你喜欢
  • 2018-06-25
  • 1970-01-01
  • 1970-01-01
  • 2011-01-19
  • 1970-01-01
  • 2010-11-13
  • 1970-01-01
  • 2015-03-27
  • 1970-01-01
相关资源
最近更新 更多