web-dev-qa-db-ja.com

log4jアペンダーのしきい値とカテゴリー

私はGoogleを使い尽くした、または少なくとも私が検索しようとしていたことを言って、この質問の序文を述べさせてください。 「log4jしきい値」、「log4jしきい値カテゴリ」、「log4jアペンダーしきい値カテゴリ」などですが、Googleから返された結果が本当にわかりません。

これは私が与えた完全な設定です。自分のニーズに合わせて変更する方法がわかりません。

<?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 [email protected] $ -->

<!--
| 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は、一致する名前のカテゴリがあり、FATALに設定されているにもかかわらず、DEBUGメッセージをダンプします。

Jbossが変更後に設定を再読み込みしていると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
24
Amy

Quartzがログに表示される理由に関する特定の質問に回答するには、Quartz構成を次のように変更する必要があります。

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

Additivity属性は、log4jにルート設定を上書きし、org.quartzに対してのみこれを使用するように指示します。

以前のバージョンの質問では、ルート要素の優先度を致命的(またはいいえ)に設定することから始めて、それらのパッケージのみをログに記録するために、これらのクラスからのメッセージのみをオンにすることを望んでいたと述べました/ classesを明示的にオンにします。

しきい値がカテゴリとどのように相互作用するかについてのあなたの質問に答えるために、基本的にそれはパブリッシュ/サブスクライブであると考えてください。カテゴリーはロガーによって公開されるものを設定し、しきい値はアペンダーのサブスクリプションレベルを設定します。

これは、カテゴリが単一のものではなく階層であるため、少し複雑です。したがって、1つのカテゴリに公開レベルを設定するということは、すべてではありません。それはあなたの場合のように、階層で上書きされるかもしれません。

25
Yishai

「<appender-ref ref = "CONSOLE" />」を<root>から<category name = "com.foo.bar">に移動します。

つまり:

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

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

コンソールに表示する設定では、デバッグメッセージが表示されないはずなので、他の設定を使用できるかどうか、またはコードによってプログラムで設定を変更していないかどうかを確認してください。