2011-09-15 32 views
4

在外部文件中,我想将我的com.foo.test类的输出记录到特定文件,但最新情况是它追加控制台日志以及文件日志。下面是我的XML配置,log4j只记录来自文件中特定类的消息

<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"/> 
<param name="DatePattern" value="'.'yyyy-MM-dd"/> 
<layout class="org.apache.log4j.PatternLayout"> 
</layout> 
</appender> 

<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="INFO"/> 

     <layout class="org.apache.log4j.PatternLayout"> 
     <param name="ConversionPattern" value="%d{ABSOLUTE} %-5p [%c{1}] %m%n"/> 
     </layout> 
    </appender> 
<appender name="MYTESTAPPENDER" class="org.jboss.logging.appender.RollingFileAppender"> 
     <errorHandler class="org.jboss.logging.util.OnlyOnceErrorHandler"/> 
     <param name="File" value="${jboss.server.home.dir}/log/mytest.log"/> 
     <param name="Append" value="false"/> 
     <param name="MaxFileSize" value="3MB"/> 
     <param name="MaxBackupIndex" value="3"/> 
     <layout class="org.apache.log4j.PatternLayout"> 
      <param name="ConversionPattern" value="%d %-5p [%c] %m%n"/> 
     </layout> 
    </appender> 
<logger name="testsplitlogger" additivity="false"> 
<level value="info"/> 
<appender-ref ref="MYTESTAPPENDER"/> 
</logger> 
<root> 
     <appender-ref ref="CONSOLE"/> 
     <appender-ref ref="FILE"/> 
     <appender-ref ref="MYTESTAPPENDER"/> 
    </root> 

而且我的Java代码,

private static final Logger logger = Logger.getLogger("testsplitlogger"); 

更新: 的问题是它记录所有控制台输出等追加程序输出到mytest.log文件,而不是我只想追加来自我的testsplitlogger的信息消息,以便从控制台中读取特定的类和其他日志,并将文件写入server.log。

我做错了什么?

回答

0

请参阅< root> xml config。您允许将日志定向到所有三个不同的文件。

  1. 控制台(的System.out)
  2. 文件(在这种情况下的server.log)和
  3. MYTESTAPPENDER(mytest.log)

你的要求,你需要像这样定义。

<root> 
<priority value="info"/>  
<!--<appender-ref ref="CONSOLE"/>-->  
<!--<appender-ref ref="FILE"/>-->  
<appender-ref ref="MYTESTAPPENDER"/>  
</root> 
+0

我已经更新了我的疑问,请查看和建议。 – Karthik

0

编辑: 看来你已经更新的问题,因为我上次张贴...所以,我提出以下建议已经被你照顾。

testsplitlogger也必须包含appender参考。

<logger name="testsplitlogger" additivity="false"> 
    <level value="info" /> 
    <appender-ref ref="MYTESTAPPENDER" /> 
</logger> 

这里是一个很好的链接,你可以参考http://wiki.apache.org/logging-log4j/Log4jXmlFormat

0

你需要创建一个Category

<category name="my.company.package" additivity="false"> 
    <priority value="info" /> 
    <appender-ref ref="MYTESTAPPENDER" /> 
</category>