我确信这很简单,但Google和SO之间我没有找到答案。
我有一个jboss 4.0.2(我知道它已经老了,但我现在无法改变它)webapp with log4j 1.2.9。我已经为控制台appender和滚动文件appender设置了日志,它们都可以正常工作。
我正在尝试设置一个日志文件来记录来自一个软件包的消息(在我的例子中,我们用于SFTP的com.sshtools软件包)。主日志失败,控制台也可以有这些消息(或不,我真的不在乎)。但是,ftp日志应该只包含来自com.sshtools包的消息。不幸的是,当我运行webapp时,FTP日志会获取所有消息,而不仅仅是FTP消息。
我目前正在使用类别来设置某些包的级别并使用appender-ref属性。我已经尝试将该包的可加性设置为false无济于事。我尝试将类别切换到记录器无济于事。我已经尝试为所有软件包设置appender-ref标签(将它们转到CONSOLE和FILE但不是FTP)无济于事。
我已经看到使用属性文件执行此操作的响应,但没有使用xml文件。由于我不知道如何从属性文件转换为xml文件,因此对我没有帮助。
我的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.RollingFileAppender">
<errorHandler class="org.jboss.logging.util.OnlyOnceErrorHandler"/>
<param name="File" value="${jboss.server.home.dir}/log/server.log"/>
<param name="Append" value="true"/>
<param name="MaxFileSize" value="20MB"/>
<param name="MaxBackupIndex" value="50"/>
<!-- 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>
<appender name="FTP" class="org.jboss.logging.appender.RollingFileAppender">
<errorHandler class="org.jboss.logging.util.OnlyOnceErrorHandler"/>
<param name="File" value="${jboss.server.home.dir}/log/ftp.log"/>
<param name="Append" value="true"/>
<param name="MaxFileSize" value="20MB"/>
<param name="MaxBackupIndex" value="50"/>
<!-- 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="INFO"/>
<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 -->
<category name="org.apache">
<priority value="INFO"/>
</category>
<!-- Limit the org.jgroups category -->
<category name="org.jgroups">
<priority value="WARN"/>
</category>
<!-- Limit apache axis -->
<category name="org.jboss.axis">
<priority value="INFO"/>
</category>
<!-- Limit JBoss categories -->
<category name="org.jboss">
<priority value="INFO"/>
</category>
<!-- Limit the JSR77 categories -->
<category name="org.jboss.management">
<priority value="INFO"/>
</category>
<!-- Limit j2ssh categories -->
<category name="com.sshtools">
<priority value="WARN"/>
<appender-ref ref="FTP"/>
</category>
<!-- Limit Hibernate categories -->
<category name="org.hibernate">
<priority value="ERROR"/>
</category>
<!-- Limit mchange categories -->
<category name="com.mchange">
<priority value="WARN"/>
</category>
<!-- ======================= -->
<!-- Setup the Root category -->
<!-- ======================= -->
<root>
<appender-ref ref="CONSOLE"/>
<appender-ref ref="FILE"/>
<appender-ref ref="FTP"/>
</root>
</log4j:configuration>
编辑:我已经尝试重新排序其中的类别和标签(不是它应该有所作为)并且仍然没有变化。
答案 0 :(得分:1)
您可以从root logger logger元素中删除FTP appender,因为FTP配置为接受来自com.sshtools包的日志记录请求。
根记录器位于记录器层次结构的顶部。针对给定记录器的每个启用的日志记录请求都将转发到该记录器中的所有appender ,以及层次结构中较高的apromders 。换句话说,appender是从记录器层次结构中附加地继承的。例如,如果将控制台appender添加到根记录器,则所有启用的记录请求将至少在控制台上打印。如果另外将文件追加器添加到记录器(例如L),则对L和L'子项启用的记录请求将打印在文件和控制台上。可以通过将additivity标志设置为false来覆盖此默认行为,以便不再添加appender累积。
我希望这会有所帮助。