2012-06-20 52 views
2

myController.java如何讓jboss顯示log.debug消息?

private static final Logger log = Logger.getLogger(myController.class 
    .getName()); 
@GET 
    @Path("/testDebug") 
    public String testDebug(@Context final ServletContext context) 
    { 
    log.error("This is an error message"); 
    log.debug("This is a debug message"); 
    log.fatal("This is fatal message"); 
    log.warn("This is a warn message"); 
    log.info("This is a info message"); 

    return "Test Page. Debug Mode is on =" + log.isDebugEnabled(); 
    } 

的jboss-log4j.xml文件

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

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

<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.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"> 
     <!-- The default pattern: Date Priority [Category] Message\n --> 
     <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{1}] %m%n"/> 
     </layout> 
    </appender> 


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

    <!-- Limit the org.apache category to INFO as its DEBUG is verbose --> 
    <category name="org.apache"> 
     <priority value="INFO"/> 
    </category> 

    <!-- Limit the org.jboss.serial (jboss-serialization) to INFO as its DEBUG is verbose --> 
    <category name="org.jboss.serial"> 
     <priority value="INFO"/> 
    </category> 

    <!-- Limit the org.jgroups category to WARN as its INFO is verbose --> 
    <category name="org.jgroups"> 
     <priority value="WARN"/> 
    </category> 

    <!-- Limit the jacorb category to WARN as its INFO is verbose --> 
    <category name="jacorb"> 
     <priority value="WARN"/> 
    </category> 

    <!-- Limit JBoss categories --> 
    <category name="org.jboss"> 
     <priority value="INFO"/> 
     <appender-ref ref="CONSOLE"/> 
    </category> 



    <!-- Limit the JSR77 categories --> 
    <category name="org.jboss.management"> 
     <priority value="INFO"/> 
    </category> 

    <!-- This is is the package to myController.java --> 
    <category name="com.myPackage.src"> 
     <priority value="DEBUG"/> 
    </category> 

    <!-- ======================= --> 
    <!-- Setup the Root category --> 
    <!-- ======================= --> 

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

</log4j:configuration> 

所需的結果

時路徑/testDebug被擊中得到的消息:「這是一個調試消息「

問題:

我得到的所有消息顯示除了調試

10:29:49,440 INFO [STDOUT] 10:29:49,440 ERROR [myController] This is an error message 
10:29:49,440 INFO [STDOUT] 10:29:49,440 FATAL [myController] This is fatal message 
10:29:49,440 INFO [STDOUT] 10:29:49,440 WARN [myController] This is a warn message 
10:29:49,440 INFO [STDOUT] 10:29:49,440 INFO [myController] This is a info message 

爲什麼不能我得到的調試消息顯示?

+0

這pacakge是 –

+0

@SurajChandran位置類是myController的com.myPackage.src.myController.java – stackoverflow

回答

0

你可以嘗試這樣做:

<category name="com.myPackage.src"> 
     <priority value="DEBUG"/> 
    </category> 
+0

我加那對我的jboss-log4j.xml。還是行不通。我仍然只獲取其他消息而不是調試消息。我在最初的問題中添加了您的反饋 – stackoverflow

0

你的類定義不正確。當你實例化你的記錄器時,你使用的是Class.getName(),它返回完全限定的類名。您只用軟件包名稱來定義記錄器類別,這意味着對於類別com.myPackage.src.myController,調試未打開。

您需要更改您實例的方式你的記錄

private static final Logger log = Logger.getLogger(myController.class.getPackage().getName()); 

或更改您的類別定義

<category name="com.myPackage.src.myController"> 
    <priority value="DEBUG"/> 
</category> 

在一個側面沒有,包不應該大寫字符和類的名稱應該始終以大寫字母開頭。

4

請參閱this question瞭解有關使用Jboss 7.1.1+查看調試日誌的更新信息。

幾點:

  1. 你的類myController使用預期的記錄。 (另一個答案聲稱,你不正確的實例記錄;不正確的

  2. 從您的項目中刪除的log4j.xml(或logback.xml等)的配置文件(即從main/resources/META-INF

  3. 在您的pom.xml中,確保您的slf4j依賴關係的範圍爲,並提供(Jboss將提供此)。此外,不要包含log4j(或logback等)實現依賴關係。例如,這裏就是你的日誌依賴部分可能看起來像:

    <dependency> 
        <groupId>org.slf4j</groupId> 
        <artifactId>slf4j-api</artifactId> 
        <version>1.7.7</version> 
        <scope>provided</scope> 
    </dependency> 
    
  4. 確保你在你的standalone/configuration/standalone.xml文件記錄進入你的包。

    <logger category="com.myPackage.src"> 
        <level name="DEBUG"/> 
    </logger> 
    
  5. 確保控制檯處理程序週期性旋轉文件處理程序處理有DEBUG的水平。 (默認情況下,他們是信息,他們將需要調試,否則你的調試語句將被忽略。)

注意,有一個命令行,讓你更新日誌。我手動做我的,但使用CLI可能是明智的。

這裏是你的standalone.xml記錄部分可以是什麼樣子的縮寫版本:

<subsystem xmlns="urn:jboss:domain:logging:2.0"> 
     <console-handler name="CONSOLE"> 
      <level name="DEBUG"/> 
      <formatter> 
       <named-formatter name="COLOR-PATTERN"/> 
      </formatter> 
     </console-handler> 
     <periodic-rotating-file-handler name="FILE" autoflush="true"> 
      <level name="DEBUG"/> 
      <formatter> 
       <named-formatter name="PATTERN"/> 
      </formatter> 
      <file relative-to="jboss.server.log.dir" path="server.log"/> 
      <suffix value=".yyyy-MM-dd"/> 
      <append value="true"/> 
     </periodic-rotating-file-handler> 
     <logger category="com.myPackage.src"> 
      <level name="DEBUG"/> 
     </logger> 
     <root-logger> 
      <level name="INFO"/> 
      <handlers> 
       <handler name="CONSOLE"/> 
       <handler name="FILE"/> 
      </handlers> 
     </root-logger> 
     <formatter name="PATTERN"> 
      <pattern-formatter pattern="%d{yyyy-MM-dd HH:mm:ss,SSS} %-5p [%c] (%t) %s%E%n"/> 
     </formatter> 
     <formatter name="COLOR-PATTERN"> 
      <pattern-formatter pattern="%K{level}%d{HH:mm:ss,SSS} %-5p [%c] (%t) %s%E%n"/> 
     </formatter> 
    </subsystem>