Java log4j只记录文件中特定类的消息

Java log4j只记录文件中特定类的消息,java,log4j,Java,Log4j,在一个外部文件中,我想将com.foo.test类的输出记录到一个特定的文件中,但实际发生的是它附加了控制台日志和文件日志。下面是我的xml配置 <appender name="FILE" class="org.jboss.logging.appender.DailyRollingFileAppender"> <errorHandler class="org.jboss.logging.util.OnlyOnceErrorHandler"/> &l

在一个外部文件中,我想将com.foo.test类的输出记录到一个特定的文件中,但实际发生的是它附加了控制台日志和文件日志。下面是我的xml配置

<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>
更新: 问题是它将所有控制台输出和其他附加程序输出记录到mytest.log文件中,而我只想将来自特定类的testsplitlogger的信息消息以及来自控制台和文件的其他日志附加到server.log中

我做错了什么吗?

请查看xml配置。您允许将日志指向所有三个不同的文件。

  • 控制台(系统输出)
  • 文件(在本例中为server.log)和
  • MYTESTAPPENDER(mytest.log)
  • 根据您的需求,您需要这样定义

    <root>
    <priority value="info"/>       
    <!--<appender-ref ref="CONSOLE"/>-->       
    <!--<appender-ref ref="FILE"/>-->       
    <appender-ref ref="MYTESTAPPENDER"/>    
    </root> 
    
    
    
    编辑: 似乎你已经更新了问题,因为我上次发布。。。所以我下面的建议已经被你们采纳了

    testsplitlogger还必须包含appender引用

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

    您需要为此创建一个:

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