log4j配置参数详解——按日志文件大小、日期切分日志文件
项目中尽管对log4j有基本的配置,例如按天生成日志文件以作区分,但如果系统日志文件过大,则就需要考虑以更小的单位切分或者其他切分方式。下面就总结一下log4j常用的配置参数以及切分日志的不同方式。
一、基本配置解析
常用配置1:
- #日志级别,还可以log4j.rootLogger=INFO,file2,file3 指定file2、3的输出文件
- log4j.rootLogger=info,exception,thread
- #info
- #每一天产生1个日志文件
- log4j.appender.info=org.apache.log4j.DailyRollingFileAppender
- #定义日志存放路径
- log4j.appender.info.File=/usr/tomcat_logs/mailSystem_info.log
- #日志文件是否追加
- log4j.appender.info.Append=true
- #定义的时间格式,如果时间定义到分钟(mm)就是每分钟生成一个日志文件,而这里定义的这个格式就是日志名后缀
- #log4j.appender.file3.DatePattern='_' yyyy-MM-dd-HH-mm 每分钟
- #log4j.appender.file3.DatePattern='_' yyyy-MM-dd-HH 每小时
- #log4j.appender.file3.DatePattern='_' yyyy-MM-dd 每天
- #log4j.appender.file3.DatePattern='_' yyyy-MM-dd-a 每半天
- #日志输出级别
- log4j.appender.info.Threshold=INFO
- #日志编码
- #log4j.appender.file3.Encoding=UTF-8
- #日志中输出的日志的格式
- log4j.appender.info.layout=org.apache.log4j.PatternLayout
- #定义的日志格式
- log4j.appender.info.layout.ConversionPattern=%t %d %p [%c] - %m%n
常用配置2:
- #debug
- log4j.appender.debug=org.apache.log4j.RollingFileAppender
- log4j.appender.debug.File=/usr/tomcat_logs/mailSystem_debug.log
- #设置日志文件的大小
- log4j.appender.debug.MaxFileSize=100M
- #保存10个备份文件
- log4j.appender.debug.MaxBackupIndex=10
- log4j.appender.debug.Append=true
- log4j.appender.debug.Threshold=DEBUG
- log4j.appender.debug.layout=org.apache.log4j.PatternLayout
- log4j.appender.debug.layout.ConversionPattern=%t %d %p [%c] - %m%n
配置1采用DailyRollingFileAppender类,可定义日志按照log4j给定的参数值进行配置,配置2使用RollingFileAppender。两者都为log4j配置的核心类。在下进行详细介绍。
二、配置核心类解析
CLASS1:DailyRollingFileAppender
在配置1中使用到DailyRollingFileAppender,该类继承与FileAppender,so
that the underlying file is rolled over at a user chosen frequency.
The rolling schedule is specified by the “DatePattern” option。使用这些rolling schedule 需要注意一个前缀问题。例如if
the “File” option is set to “/foo/bar.log” and the “DatePattern” set to '.'yyyy-MM-dd ,则到了midnight,the logging file /foo/bar.log will be copied to
"/foo/bar.log.2017-01-01",也就是在bar.log文件后添加 ".yyyy-MM-dd"后缀。It is possible to specify monthly,
weekly,half-daily, daily,hourly, or minutely rollover schedules.
总共有:
切分类型 |
切分前 |
切分后 |
按月'.'yyyy-MM |
/foo/bar.log |
/foo/bar.log.2002-05 |
按周 '.'yyyy-ww |
/foo/bar.log |
/foo/bar.log.2002-23 |
按天 '.'yyyy-MM-dd |
/foo/bar.log |
/foo/bar.log.2002-03-08 default |
半天 '.'yyyy-MM-dd-a |
/foo/bar.log |
/foo/bar.log.2002-03-09-AM |
按时 '.'yyyy-MM-dd-HH |
/foo/bar.log |
/foo/bar.log.2002-03-09-10 |
按分 '.'yyyy-MM-dd-HH-mm |
/foo/bar.log |
/foo/bar.log.2001-03-09-10-22 |
- public DailyRollingFileAppender (Layout layout, String filename,
- String datePattern) throws IOException {
- super(layout, filename, true);
- this.datePattern = datePattern;
- activateOptions();
- }
这些参数策略会传入到DailyRollingFileAppender的初始化方法中,创建一个DailyRollingFileAppender对象。
CLASS2:RollingFileAppender
配置2中使用到另一个类RollingFileAppender,这个类也继承子FileAppender,用于按照一定的size文件大小,back up 日志文件。
这个类中起关键作用的两个参数maxFileSize和maxBackupIndex,用于确定每个日志文件的size大小和备份个数。默认分别为10MB和1.按照设置的index大小,会默认将文件copy
to .1,.2等文件后缀进行备份。
CLASS3: PatternLayout
在两个配置中,均使用PatternLayout和ConventionPattern类,PatternLayout主要用于日志输出相关,ConventionPattern用于定义日志文件的输出格式。其中ConventionPattern支持多种类型的日志输出,如线程信息、类信息,均已%打头进行配置,详情如下:
%c
输出日志信息所属的类的全名,例如%c{2},对于com.max.spring.demo,便会输出spring.demo两级类信息。
%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy-MM-dd HH:mm:ss },输出类似:2002-10-18- 22:10:28
%f 输出日志信息所属的类的类名
%l 输出日志事件的发生位置,即输出日志信息的语句处于它所在的类的第几行
%m 输出代码中指定的信息,如log(message)中的message
%n 输出一个回车换行符,Windows平台为“rn”,Unix平台为“n”
%p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL。如果是调用debug()输出的,则为DEBUG,依此类推
%r 输出自应用启动到输出该日志信息所耗费的毫秒数
%t 输出产生该日志事件的线程名
三、切分效果
按照日期切分日志: 按照文件大小切分日志:
log4j配置参数详解——按日志文件大小、日期切分日志文件的更多相关文章
- zookeeper的配置参数详解(zoo.cfg)
配置参数详解(主要是%ZOOKEEPER_HOME%/conf/zoo.cfg文件) 参数名 说明 clientPort 客户端连接server的端口,即对外服务端口,一般设置为2181吧. data ...
- [转帖]持久化journalctl日志清空命令查看配置参数详解
持久化journalctl日志清空命令查看配置参数详解 最近 linux上面部署服务 习惯使用systemd 进行处理 这样最大的好处能够 使用journalctl 进行查看日志信息. 今天清理了下 ...
- mha配置参数详解
mha配置参数详解: 参数名字 是否必须 参数作用域 默认值 示例 hostname Yes Local Only - hostname=mysql_server1, hostname=192.168 ...
- reids配置参数详解
转自:http://www.jb51.net/article/60627.htm reids配置参数详解 #daemonize no 默认情况下, redis 不是在后台运行的,如果需要在后台运行, ...
- nginx配置参数详解
配置参数详解 user nginx nginx ; Nginx用户及组:用户 组.window下不指定 worker_processes 8; 工作进程:数目.根据硬件调整,通常等于CPU数量或者2倍 ...
- Redis配置参数详解
Redis配置参数详解 /********************************* GENERAL *********************************/ // 是否作为守护进 ...
- MHA配置参数详解 【转】
mha配置参数详解: 参数名字 是否必须 参数作用域 默认值 示例 hostname Yes Local Only - hostname=mysql_server1, hostname=192.168 ...
- HAproxy 配置参数详解
HAproxy 配置参数详解 /etc/haproxy/haproxy.cfg # 配置文件 ----------------------------------------------------- ...
- samba 配置参数详解
samba 配置参数详解: 一.全局配置参数 workgroup = WORKGROUP说明:设定 Samba Server 所要加入的工作组或者域. server string = Samba S ...
随机推荐
- 简单的物流项目实战,WPF的MVVM设计模式(二)
往Models文件添加一个类,ConnectObject /// <summary> /// 链接数据库字符串 /// </summary ...
- 2018 Web 开发者路线图[转载]
2018 Web 开发者路线图[转载] https://qianduan.group/posts/5a66f36e0cf6b624d2239c74?hmsr=toutiao.io&utm_me ...
- 简单Spring Cloud 微服务框架搭建
微服务是现在比较流行的技术,对于程序猿而言,了解并搭建一个基本的微服务框架是很有必要滴. 微服务包含的内容非常多,一般小伙伴们可以根据自己的需求不断添加各种组件.框架. 一般情况下,基本的微服务框架包 ...
- [git]git的分支管理
最近在折腾git,有感于git这个强大而好用的版本管理工具. 说说git分支管理的心得体会. 首先,要有个master主分支: Git主分支的名字,默认叫做Master.它是自动建立的,版本库初始化以 ...
- Linux openssh8.0p1升级步骤
前期准备开启本机telnet服务,以防openssh升级失败无法连接服务器.注:redhat 5 6 和 redhat7 开机启动配置相关文件不同,请注意 1.安装zlibtar -xzvf zlib ...
- Vscode窗口被覆盖
用Vscode用的好好的,突然就发现窗口被覆盖了 解决办法如下:1.ctrl+shift+p 快捷键打开如下界面, 2.接着在搜索框中输入settings,点击首先项:打开设置(json) 3.再se ...
- pyqt5-QPlainTextEdit普通文本
继承:QAbstractScrollArea QPlainText和QTextEdit大致功能实现差不多,不能有图片.框架.表格等 QPlainText是安行滚动的,QTextEdit是安像素滚动的 ...
- Zookeeper实现哨兵机制
master选举使用场景及结构 现在很多时候我们的服务需要7*24小时工作,假如一台机器挂了,我们希望能有其它机器顶替它继续工作.此类问题现在多采用master-salve模式,也就是常说的主从模式, ...
- 大数据学习笔记之初识Hadoop
1.Hadoop概述 1.1 Hadoop名字的由来 Hadoop项目作者的孩子给一个棕黄色的大象样子的填充玩具的命名 Hadoop的官网:http://hadoop.apache.org . 1.2 ...
- POJ 1743 Musical Theme ( 后缀数组 && 最长不重叠相似子串 )
题意 : 给 n 个数组成的串,求是否有多个“相似”且不重叠的子串的长度大于等于5,两个子串相似当且仅当长度相等且每一位的数字差都相等. 分析 : 根据题目对于 “ 相似 ” 串的定义,我们可以将原 ...