Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/iphone/39.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 拆分包和类日志记录_Java_Log4j - Fatal编程技术网

Java 拆分包和类日志记录

Java 拆分包和类日志记录,java,log4j,Java,Log4j,我想为某些类配置记录器,以便写入单独的文件。 但是对于包记录器,我有相同的级别,消息被写入两次 以下是我的配置: <appender name="FILE_TRACE" class="org.apache.log4j.RollingFileAppender"> <param name="File" value="c:/logs/trace.log"/> <param name="MaxFileSize" value="100MB"/>

我想为某些类配置记录器,以便写入单独的文件。 但是对于包记录器,我有相同的级别,消息被写入两次

以下是我的配置:

<appender name="FILE_TRACE" class="org.apache.log4j.RollingFileAppender">
    <param name="File" value="c:/logs/trace.log"/>
    <param name="MaxFileSize" value="100MB"/>
    <layout class="org.apache.log4j.PatternLayout">
        <param name="ConversionPattern" value="%X{user} - %X{docbase} - %X{sysObjectId} - %d{ABSOLUTE} [%t] %m%n"/>
    </layout>
</appender>

<appender name="QUERY_TRACE" class="org.apache.log4j.RollingFileAppender">
    <param name="File" value="c:/logs/query.log"/>
    <param name="MaxFileSize" value="100MB"/>
    <layout class="org.apache.log4j.PatternLayout">
        <param name="ConversionPattern" value="%X{user} - %X{docbase} - %X{sysObjectId} - %d{ABSOLUTE} [%t] %m%n"/>
    </layout>
</appender>

<appender name="stdout" class="org.apache.log4j.ConsoleAppender">
    <layout class="org.apache.log4j.PatternLayout">
        <param name="ConversionPattern" value="[%d{ISO8601}|%-5p|%-22t|%C|%M|%-4L] %m%n"/>
    </layout>
</appender>

   <logger name="package">
        <level value="DEBUG"/>
        <appender-ref ref="FILE_TRACE"/>
    </logger>

    <logger name="package.MyClass">
        <level value="DEBUG" />
        <appender-ref ref="QUERY_TRACE"/>
    </logger>

    <root>
        <level value="INFO"/>
        <appender-ref ref="stdout"/>
    </root>


层次结构中的“上层”记录器不会记录来自
包的消息。MyClass

有一个类似问题的配置标志,它名为additivity,但我很久以前就使用过。请在此处阅读有关additivity的内容
Logger.getLogger(this);
<logger name="package.MyClass" additivity="false">
        <level value="DEBUG" />
        <appender-ref ref="QUERY_TRACE"/>
</logger>