Вопрос по configuration – порог и категория приложения log4j

24

Позвольте мне в начале этого вопроса сказать, что я исчерпал Google или, по крайней мере, то, что я пытался найти. «порог log4j», «пороговая категория log4j», «пороговая категория log4j appender» и т. д. Но я действительно не понимаю, какие результаты я получаю от 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 выводит сообщения 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) и фактический проблемный вывод консоли? Yishai
Ишай: Я обновил вопрос. Amy

Ваш Ответ

2   ответа
25

почему Quartz отображается в журнале, вам необходимо изменить конфигурацию Quartz следующим образом:

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

Атрибут additivity указывает log4j переопределить корневой параметр и использовать его только для org.quartz.

В предыдущей версии вопроса, который вы указали, вы хотели, чтобы включались только те сообщения из этих классов, для этого вам нужно начать с настройки приоритета в корневом элементе на fatal (или даже NO), а затем он будет регистрировать только эти пакеты / классы, которые вы включаете явно.

Чтобы ответить на ваш вопрос о том, как порог взаимодействует с категорией, в основном подумайте о ней как о публикации / подписке. Категория устанавливает то, что публикуется регистратором, а порог - уровень подписки аппендера.

Это немного усложняется тем фактом, что категория - это не отдельная вещь, а скорее иерархия, поэтому тот факт, что вы устанавливаете уровень публикации для одной категории, - это не вся история. Это может быть переопределено в иерархии, как это было в вашем случае.

Спасибо вам большое! Amy
@davidfrancis, JBoss, вероятно, устанавливает уровень корня на что-то другое, чем вы есть в вашем автономном режиме. Я думаю, что вопрос и ответ остаются в силе.
Я нашел этот вопрос и ответ очень запутанным. Я считаю, что вопрос редактировался несколько раз, поэтому этот ответ в настоящее время вводит в заблуждение. Конечно, если я использую данный log4j xml, я делаюnot получать любые сообщения INFO или DEBUG Quartz - они ограничены FATAL. Примечание: я проверял это в отдельной программе, а не в JBoss, поэтому я не знаю, делает ли JBoss что-то умное / отличное от log4j.
Справедливо, если вопрос и ответ рассматриваются как специфичные для JBoss, то я думаю, что вы правы. Проблема в том, что вопрос довольно общий. Меня очень смутило, но в этом нет ничего нового;]
4

appender-ref ref = "CONSOLE" / & gt; " от & lt; root & gt; to & lt; имя категории = "com.foo.bar" & gt ;.

т.е .:

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

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

С конфигурацией, которую вы показываете, консоль не должна получать никаких сообщений отладки, поэтому проверьте, можно ли использовать любую другую конфигурацию или какой-либо код программно изменяет конфигурацию.

То, что JBoss перезагружается, не означает, что это то, что используется. Посмотрите отладку до истины для корневого элемента log4j, и вывод может помочь вам увидеть, что идет не так.
Я обновил вопрос с помощью полной конфигурации и примерами того, о чем я говорю. Amy
Спасибо ... с этим предложением все в порядке. Моя проблема была устранена после удаления объявления appender из & lt; root & gt; тег.

Похожие вопросы