博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Log4j 配置
阅读量:5879 次
发布时间:2019-06-19

本文共 2602 字,大约阅读时间需要 8 分钟。

Log4j官方的appender给出了一下几种实现

 

org.apache.log4j.ConsoleAppender(控制台),  

org.apache.log4j.FileAppender(文件),  

org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件),  

org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件),  

org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)

 

实际开发我们使用第1,第3和第4种实现;

 

假如日志数据量不是很大,我们可以用DailyRollingFileAppender 每天产生一个日志,方便查看;

假如日志数据量很大,我们一般用RollingFileAppender,固定尺寸的日志,假如超过了 就产生一个新的文件;

 

我们这里给出一些实例;

log4j.rootLogger=DEBUG, Console ,File ,DailyRollingFile ,RollingFile    #Console  log4j.appender.Console=org.apache.log4j.ConsoleAppender  log4j.appender.Console.layout=org.apache.log4j.PatternLayout  log4j.appender.Console.layout.ConversionPattern=%d [%t] %-5p [%c] - %m%n    #Filelog4j.appender.File = org.apache.log4j.FileAppenderlog4j.appender.File.File = C://log2.loglog4j.appender.File.layout = org.apache.log4j.PatternLayoutlog4j.appender.File.layout.ConversionPattern =%d [%t] %-5p [%c] - %m%n #DailyRollingFilelog4j.appender.DailyRollingFile = org.apache.log4j.DailyRollingFileAppenderlog4j.appender.DailyRollingFile.File = C://log3.loglog4j.appender.DailyRollingFile.layout = org.apache.log4j.PatternLayoutlog4j.appender.DailyRollingFile.layout.ConversionPattern =%d [%t] %-5p [%c] - %m%n #RollingFilelog4j.appender.RollingFile = org.apache.log4j.RollingFileAppenderlog4j.appender.RollingFile.File = C://log4.loglog4j.appender.RollingFile.MaxFileSize=1KBlog4j.appender.RollingFile.MaxBackupIndex=3log4j.appender.RollingFile.layout = org.apache.log4j.PatternLayoutlog4j.appender.RollingFile.layout.ConversionPattern =%d [%t] %-5p [%c] - %m%n

测试代码:

package com.open1111; import org.apache.log4j.Logger; public class Test {     private static Logger logger=Logger.getLogger(Test.class); // 获取logger实例         public static void main(String[] args) {        logger.info("普通Info信息");        logger.debug("调试debug信息");        logger.error("报错error信息");        logger.warn("警告warn信息");        logger.fatal("严重错误fatal信息");                 logger.error("报错信息", new IllegalArgumentException("非法参数"));        int i=0;        while(i<10000){            logger.debug(" RollingFile 调试debug信息");            logger.debug(" RollingFile 调试debug信息");            logger.debug(" RollingFile 调试debug信息");            logger.debug(" RollingFile 调试debug信息");            logger.debug(" RollingFile 调试debug信息");            i++;        }    }     }

这里有两个新的配置项解释下:

MaxFileSize 是日志文件的最大尺寸;根据实际需求来定 10KB 100KB也行

MaxBackupIndex是日志文件的个数,假如超过了,则覆盖,主要考虑到的是硬盘的容量问题;根据实际需求来定 比如 100  500;

 

这里给下日志文件的效果:

DailyRollingFileAppender  效果:

QQ鎴浘20170328152805.jpg

 

RollingFileAppender 效果:

QQ鎴浘20170328153449.jpg

 
分类: 

转载于:https://www.cnblogs.com/maohuidong/p/9310453.html

你可能感兴趣的文章
【OpenStack】network相关知识学习
查看>>
centos 7下独立的python 2.7环境安装
查看>>
[日常] 算法-单链表的创建
查看>>
前端工程化系列[01]-Bower包管理工具的使用
查看>>
使用 maven 自动将源码打包并发布
查看>>
Spark:求出分组内的TopN
查看>>
Python爬取豆瓣《复仇者联盟3》评论并生成乖萌的格鲁特
查看>>
关于跨DB增量(增、改)同步两张表的数据小技巧
查看>>
飞秋无法显示局域网好友
查看>>
学员会诊之03:你那惨不忍睹的三层架构
查看>>
vue-04-组件
查看>>
Golang协程与通道整理
查看>>
解决win7远程桌面连接时发生身份验证错误的方法
查看>>
C/C++ 多线程机制
查看>>
js - object.assign 以及浅、深拷贝
查看>>
python mysql Connect Pool mysql连接池 (201
查看>>
Boost在vs2010下的配置
查看>>
一起谈.NET技术,ASP.NET伪静态的实现及伪静态的意义
查看>>
20款绝佳的HTML5应用程序示例
查看>>
string::c_str()、string::c_data()及string与char *的正确转换
查看>>