需要的包和测试的代码下载附件!
如果需要将不同的日志打印到不同的地方,则需要定义不同的Appender,然后定义每一个 Appender的日志级别、打印形式、输出位置!
配置log4j.properties文件如下:
01 #########################################################################################
02 # 日志信息配置
03 LOG_DIR=c://logtest/
04 log4j.rootLogger=WARN,rootlog,logSay
05 #########################################################################################
06 # 主日志控制 1G 30个循环文件 记录所有打印内容,不需要可以取消
07 log4j.appender.rootlog=org.apache.log4j.DailyRollingFileAppender
08 log4j.appender.rootlog.file=${LOG_DIR}/logtest.log
09 log4j.appender.rootlog.layout=org.apache.log4j.PatternLayout
10 log4j.appender.rootlog.layout.ConversionPattern=%-d{yyyy-MM-dd HH\:mm\:ss} [%c-%L]-[%p] %m%n
11 #########################################################################################
12 # 打印到控制台
13 log4j.appender.logSay=org.apache.log4j.ConsoleAppender
14 log4j.appender.logSay.Target=System.out
15 log4j.appender.logSay.layout=org.apache.log4j.PatternLayout
16 log4j.appender.logSay.layout.ConversionPattern=%-d{yyyy-MM-dd HH\:mm\:ss} [%c-%L]-[%p] %m%n
17 #########################################################################################
18 # test日志打印 10M 2个循环文件
19 log4j.logger.com.cui.log.test1=warn,test
20 log4j.appender.test=org.apache.log4j.RollingFileAppender
21 log4j.appender.test.MaxFileSize=10240KB
22 log4j.appender.test.MaxBackupIndex=2
23 log4j.appender.test.File=${LOG_DIR}/test.log
24 log4j.appender.test.layout=org.apache.log4j.PatternLayout
25 log4j.appender.test.layout.ConversionPattern=%-d{yyyy-MM-dd HH\:mm\:ss} [%c-%L]-[%p] %m%n
26 #########################################################################################
27 # test2日志打印 10M 2个循环文件
28 log4j.logger.com.cui.log.test2=debug,test2
29 log4j.appender.test2=org.apache.log4j.RollingFileAppender
30 log4j.appender.test2.MaxFileSize=10240KB
31 log4j.appender.test2.MaxBackupIndex=2
32 log4j.appender.test2.File=${LOG_DIR}/test2.log
33 log4j.appender.test2.layout=org.apache.log4j.PatternLayout
34 log4j.appender.test2.layout.ConversionPattern=%-d{yyyy-MM-dd HH\:mm\:ss} [%c-%L]-[%p] %m%n
35 #########################################################################################
定义了一个主输出配置,然后定义了两个包的各自打印行为:
01 package com.cui.log.test1;
02 import org.apache.commons.logging.Log;
03 import org.apache.commons.logging.LogFactory;
04 /**
05 * @说明 日志打印测试
06 * @author 崔素强
07 * @version 1.0
08 * @since
09 */
10 public class Test1 {
11 /**
12 * 日志记录对象
13 */
14 private static Log log = LogFactory.getLog(Test1.class);
15 /**
16 * 测试
17 * @param args
18 */
19 public static void main(String[] args) {
20 log.debug("Test1");
21 log.warn("Test1");
22 log.info("Test1");
23 log.error("Test1");
24 }
25 }
另外一个不同包的代码:
01 package com.cui.log.test2;
02 import java.io.IOException;
03 import org.apache.commons.logging.Log;
04 import org.apache.commons.logging.LogFactory;
05 /**
06 * @说明 日志打印测试
07 * @author 崔素强
08 * @version 1.0
09 * @since
10 */
11 public class Test2 {
12 /**
13 * 日志记录对象
14 */
15 private static Log log = LogFactory.getLog(Test2.class);
16 /**
17 * 测试
18 * @param args
19 */
20 public static void main(String[] args) throws IOException {
21 log.debug("Test2");
22 log.warn("Test2");
23 log.info("Test2");
24 log.error("Test2");
25 }
26 }
我们对两个不同打印的日志级别输出是不一样的,控制台也会根据各自配置进行打印,运行两个类!
控制台:
1 2012-11-27 14:03:50 [com.cui.log.test1.Test1-21]-[WARN] Test1
2 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
2 2012-11-27 14:04:06 [com.cui.log.test2.Test2-22]-[WARN] Test2
3 2012-11-27 14:04:06 [com.cui.log.test2.Test2-23]-[INFO] Test2
4 2012-11-27 14:04:06 [com.cui.log.test2.Test2-24]-[ERROR] Test2
看输出文件打印:
主文件logtest.log:
1 2012-11-27 14:03:50 [com.cui.log.test1.Test1-21]-[WARN] Test1
2 2012-11-27 14:03:50 [com.cui.log.test1.Test1-23]-[ERROR] Test1
3 2012-11-27 14:04:06 [com.cui.log.test2.Test2-21]-[DEBUG] Test2
4 2012-11-27 14:04:06 [com.cui.log.test2.Test2-22]-[WARN] Test2
5 2012-11-27 14:04:06 [com.cui.log.test2.Test2-23]-[INFO] Test2
6 2012-11-27 14:04:06 [com.cui.log.test2.Test2-24]-[ERROR] Test2
测试1文件test.log:
1 2012-11-27 14:03:50 [com.cui.log.test1.Test1-21]-[WARN] Test1
2 2012-11-27 14:03:50 [com.cui.log.test1.Test1-23]-[ERROR] Test1
测试2文件test2.log:
1 2012-11-27 14:04:06 [com.cui.log.test2.Test2-21]-[DEBUG] Test2
2 2012-11-27 14:04:06 [com.cui.log.test2.Test2-22]-[WARN] Test2
3 2012-11-27 14:04:06 [com.cui.log.test2.Test2-23]-[INFO] Test2
4 2012-11-27 14:04:06 [com.cui.log.test2.Test2-24]-[ERROR] Test2
分享到:
相关推荐
Log4j2实现不同线程不同级别日志输出到不同的文件中 源码+log4j jar包
SSM框架log4j.properties日志打印必备包SSM框架log4j.properties日志打印必备包SSM框架log4j.properties日志打印必备包SSM框架log4j.properties日志打印必备包
日志打印文件log4j日志打印文件log4j日志打印文件log4j日志打印文件log4j日志打印文件log4j
mybatis,log4j打印日志到后台和文件
Log4j采用分模块输出不同日志文件的配置
log4j-如何将日志打印到控制台? : https://blog.csdn.net/u011479200/article/details/102459717
log4j、日志输出、自定义日志、多文件输出。
log4j 日志服务器 一个系统可能有多个子系统组成,这些子系统都有自己的日志,并且运行在不同的操作系统和主机上,收集这些日志对运营人员来说也比较困难。 因此决定在平台中采用日志服务器来做到集中日志管理,平台...
log4j日志打印,直接写到控制台和sd卡上,方便使用
java利用log4j打印日志文件的示例demo,分享给大家
不用多说了吧,java人都知道,高手不用看了。
ssm框架的log4j日志打印文件
1.该工程为maven构建,要有maven环境 2.支持异步打印 3.支持多线程打印
一直在使用log4j 每天输出到一个日志文件中,该文件名为:“XXX_年月日时分.log”的形式。 这是一个eclipse工程,最简单的配置实现上述功能。
几乎是网上 能找到的 日志脱敏的所有实现 1、基于正则表达式的 日志脱敏实现 ,扩展logback 、log4j 2、springmvc 返回报文脱敏。 3、基于注解方式的脱敏。 大家选择使用。
log4j.properties配置分级别单独打印
log4j日志文件 src/log4j.properties 打印服务启动信息
今天小编就为大家分享一篇关于Tomcat使用Log4j输出catalina.out日志,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
自己写的一个日志记录工具,希望各位同志提提意见,谢谢了