Log 4 j異なるパッケージのログを異なる場所に印刷する
必要なパッケージとテストのコードは添付ファイルをダウンロードします!
異なるログを異なる場所に印刷する必要がある場合は、異なるAppenderを定義し、各Appenderのログレベル、印刷形式、出力位置を定義する必要があります.
log 4 jを構成する.propertiesファイルは次のとおりです.
プライマリ出力構成を定義し、2つのパッケージのそれぞれの印刷動作を定義します.
別の異なるパッケージのコード:
2つの異なる印刷のログレベルの出力は異なり、コンソールもそれぞれの構成に基づいて印刷し、2つのクラスを実行します.
コンソール:
もう1つ:
出力ファイルを見て印刷:
プライマリファイルlog:
テスト1ファイルlog:
テスト2ファイルtest 2.log:
ITEYEサイトでオリジナルをご覧ください.ありがとうございます.
http://cuisuqiang.iteye.com/ !
自作ブログアドレス:http://www.javacui.com/、内容はITEYEと同期!
異なるログを異なる場所に印刷する必要がある場合は、異なるAppenderを定義し、各Appenderのログレベル、印刷形式、出力位置を定義する必要があります.
log 4 jを構成する.propertiesファイルは次のとおりです.
#########################################################################################
#
LOG_DIR=c://logtest/
log4j.rootLogger=WARN,rootlog,logSay
#########################################################################################
# 1G 30 ,
log4j.appender.rootlog=org.apache.log4j.DailyRollingFileAppender
log4j.appender.rootlog.file=${LOG_DIR}/logtest.log
log4j.appender.rootlog.layout=org.apache.log4j.PatternLayout
log4j.appender.rootlog.layout.ConversionPattern=%-d{yyyy-MM-dd HH\:mm\:ss} [%c-%L]-[%p] %m%n
#########################################################################################
#
log4j.appender.logSay=org.apache.log4j.ConsoleAppender
log4j.appender.logSay.Target=System.out
log4j.appender.logSay.layout=org.apache.log4j.PatternLayout
log4j.appender.logSay.layout.ConversionPattern=%-d{yyyy-MM-dd HH\:mm\:ss} [%c-%L]-[%p] %m%n
#########################################################################################
# test 10M 2
log4j.logger.com.cui.log.test1=warn,test
log4j.appender.test=org.apache.log4j.RollingFileAppender
log4j.appender.test.MaxFileSize=10240KB
log4j.appender.test.MaxBackupIndex=2
log4j.appender.test.File=${LOG_DIR}/test.log
log4j.appender.test.layout=org.apache.log4j.PatternLayout
log4j.appender.test.layout.ConversionPattern=%-d{yyyy-MM-dd HH\:mm\:ss} [%c-%L]-[%p] %m%n
#########################################################################################
# test2 10M 2
log4j.logger.com.cui.log.test2=debug,test2
log4j.appender.test2=org.apache.log4j.RollingFileAppender
log4j.appender.test2.MaxFileSize=10240KB
log4j.appender.test2.MaxBackupIndex=2
log4j.appender.test2.File=${LOG_DIR}/test2.log
log4j.appender.test2.layout=org.apache.log4j.PatternLayout
log4j.appender.test2.layout.ConversionPattern=%-d{yyyy-MM-dd HH\:mm\:ss} [%c-%L]-[%p] %m%n
#########################################################################################
プライマリ出力構成を定義し、2つのパッケージのそれぞれの印刷動作を定義します.
package com.cui.log.test1;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
/**
* @
* @author
* @version 1.0
* @since
*/
public class Test1 {
/**
*
*/
private static Log log = LogFactory.getLog(Test1.class);
/**
*
* @param args
*/
public static void main(String[] args) {
log.debug("Test1");
log.warn("Test1");
log.info("Test1");
log.error("Test1");
}
}
別の異なるパッケージのコード:
package com.cui.log.test2;
import java.io.IOException;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
/**
* @
* @author
* @version 1.0
* @since
*/
public class Test2 {
/**
*
*/
private static Log log = LogFactory.getLog(Test2.class);
/**
*
* @param args
*/
public static void main(String[] args) throws IOException {
log.debug("Test2");
log.warn("Test2");
log.info("Test2");
log.error("Test2");
}
}
2つの異なる印刷のログレベルの出力は異なり、コンソールもそれぞれの構成に基づいて印刷し、2つのクラスを実行します.
コンソール:
2012-11-27 14:03:50 [com.cui.log.test1.Test1-21]-[WARN] Test1
2012-11-27 14:03:50 [com.cui.log.test1.Test1-23]-[ERROR] Test1
もう1つ:
2012-11-27 14:04:06 [com.cui.log.test2.Test2-21]-[DEBUG] Test2
2012-11-27 14:04:06 [com.cui.log.test2.Test2-22]-[WARN] Test2
2012-11-27 14:04:06 [com.cui.log.test2.Test2-23]-[INFO] Test2
2012-11-27 14:04:06 [com.cui.log.test2.Test2-24]-[ERROR] Test2
出力ファイルを見て印刷:
プライマリファイルlog:
2012-11-27 14:03:50 [com.cui.log.test1.Test1-21]-[WARN] Test1
2012-11-27 14:03:50 [com.cui.log.test1.Test1-23]-[ERROR] Test1
2012-11-27 14:04:06 [com.cui.log.test2.Test2-21]-[DEBUG] Test2
2012-11-27 14:04:06 [com.cui.log.test2.Test2-22]-[WARN] Test2
2012-11-27 14:04:06 [com.cui.log.test2.Test2-23]-[INFO] Test2
2012-11-27 14:04:06 [com.cui.log.test2.Test2-24]-[ERROR] Test2
テスト1ファイルlog:
2012-11-27 14:03:50 [com.cui.log.test1.Test1-21]-[WARN] Test1
2012-11-27 14:03:50 [com.cui.log.test1.Test1-23]-[ERROR] Test1
テスト2ファイルtest 2.log:
2012-11-27 14:04:06 [com.cui.log.test2.Test2-21]-[DEBUG] Test2
2012-11-27 14:04:06 [com.cui.log.test2.Test2-22]-[WARN] Test2
2012-11-27 14:04:06 [com.cui.log.test2.Test2-23]-[INFO] Test2
2012-11-27 14:04:06 [com.cui.log.test2.Test2-24]-[ERROR] Test2
ITEYEサイトでオリジナルをご覧ください.ありがとうございます.
http://cuisuqiang.iteye.com/ !
自作ブログアドレス:http://www.javacui.com/、内容はITEYEと同期!