项目中尽管对log4j有基本的配置,例如按天生成日志文件以作区分,但如果系统日志文件过大,则就需要考虑以更小的单位切分或者其他切分方式。下面就总结一下log4j常用的配置参数以及切分日志的不同方式。

一、基本配置解析

常用配置1:

  1. #日志级别,还可以log4j.rootLogger=INFO,file2,file3 指定file2、3的输出文件
  2. log4j.rootLogger=info,exception,thread
  3. #info
  4. #每一天产生1个日志文件
  5. log4j.appender.info=org.apache.log4j.DailyRollingFileAppender
  6. #定义日志存放路径
  7. log4j.appender.info.File=/usr/tomcat_logs/mailSystem_info.log
  8. #日志文件是否追加
  9. log4j.appender.info.Append=true
  10. #定义的时间格式,如果时间定义到分钟(mm)就是每分钟生成一个日志文件,而这里定义的这个格式就是日志名后缀
  11. #log4j.appender.file3.DatePattern='_' yyyy-MM-dd-HH-mm  每分钟
  12. #log4j.appender.file3.DatePattern='_' yyyy-MM-dd-HH    每小时
  13. #log4j.appender.file3.DatePattern='_' yyyy-MM-dd    每天
  14. #log4j.appender.file3.DatePattern='_' yyyy-MM-dd-a  每半天
  15. #日志输出级别
  16. log4j.appender.info.Threshold=INFO
  17. #日志编码
  18. #log4j.appender.file3.Encoding=UTF-8
  19. #日志中输出的日志的格式
  20. log4j.appender.info.layout=org.apache.log4j.PatternLayout
  21. #定义的日志格式
  22. log4j.appender.info.layout.ConversionPattern=%t %d %p [%c] - %m%n

常用配置2:

  1. #debug
  2. log4j.appender.debug=org.apache.log4j.RollingFileAppender
  3. log4j.appender.debug.File=/usr/tomcat_logs/mailSystem_debug.log
  4. #设置日志文件的大小
  5. log4j.appender.debug.MaxFileSize=100M
  6. #保存10个备份文件
  7. log4j.appender.debug.MaxBackupIndex=10
  8. log4j.appender.debug.Append=true
  9. log4j.appender.debug.Threshold=DEBUG
  10. log4j.appender.debug.layout=org.apache.log4j.PatternLayout
  11. 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

  1. public DailyRollingFileAppender (Layout layout, String filename,
  2. String datePattern) throws IOException {
  3. super(layout, filename, true);
  4. this.datePattern = datePattern;
  5. activateOptions();
  6. }

这些参数策略会传入到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 输出产生该日志事件的线程名

三、切分效果

按照日期切分日志:           按照文件大小切分日志:

                

版权声明:本文为博主原创文章,未经博主允许不得转载。 http://blog.csdn.net/Daybreak1209/article/details/54020497

log4j配置参数详解——按日志文件大小、日期切分日志文件的更多相关文章

  1. zookeeper的配置参数详解(zoo.cfg)

    配置参数详解(主要是%ZOOKEEPER_HOME%/conf/zoo.cfg文件) 参数名 说明 clientPort 客户端连接server的端口,即对外服务端口,一般设置为2181吧. data ...

  2. [转帖]持久化journalctl日志清空命令查看配置参数详解

    持久化journalctl日志清空命令查看配置参数详解 最近 linux上面部署服务 习惯使用systemd 进行处理 这样最大的好处能够 使用journalctl 进行查看日志信息. 今天清理了下 ...

  3. mha配置参数详解

    mha配置参数详解: 参数名字 是否必须 参数作用域 默认值 示例 hostname Yes Local Only - hostname=mysql_server1, hostname=192.168 ...

  4. reids配置参数详解

    转自:http://www.jb51.net/article/60627.htm reids配置参数详解 #daemonize no  默认情况下, redis 不是在后台运行的,如果需要在后台运行, ...

  5. nginx配置参数详解

    配置参数详解 user nginx nginx ; Nginx用户及组:用户 组.window下不指定 worker_processes 8; 工作进程:数目.根据硬件调整,通常等于CPU数量或者2倍 ...

  6. Redis配置参数详解

    Redis配置参数详解 /********************************* GENERAL *********************************/ // 是否作为守护进 ...

  7. MHA配置参数详解 【转】

    mha配置参数详解: 参数名字 是否必须 参数作用域 默认值 示例 hostname Yes Local Only - hostname=mysql_server1, hostname=192.168 ...

  8. HAproxy 配置参数详解

    HAproxy 配置参数详解 /etc/haproxy/haproxy.cfg # 配置文件 ----------------------------------------------------- ...

  9. samba 配置参数详解

    samba 配置参数详解: 一.全局配置参数  workgroup = WORKGROUP说明:设定 Samba Server 所要加入的工作组或者域. server string = Samba S ...

随机推荐

  1. 将Medium中的博客导出成markdown

    Medium(https://medium.com)(需要翻墙访问)是国外非常知名的一个博客平台.上面经常有很多知名的技术大牛在上面发布博客,现在一般国内的搬运的技术文章大多数都是来自于这个平台. M ...

  2. SPSS Statistics 多个版本的下载安装激活步骤

    SPSS 23:https://www.cnblogs.com/coco56/p/11648386.html SPSS25:https://www.cnblogs.com/coco56/p/11648 ...

  3. 使用modelsim直接仿真IP(FIFO)

      不通过quartus仿真,简单的仿真,就不用建立工程了,直接建立个简单的库 1.改变当前modelsim的工作路径到quartus工程的根目录下 2.新建库 3.添加必要的文件 这里第一个框,要选 ...

  4. Python3 获取当前文件名

    #__author: mac#date: 2018/12/16 import osimport sys print(__file__)print(sys.argv[0])print(os.path.d ...

  5. 深度强化学习(Deep Reinforcement Learning)入门:RL base & DQN-DDPG-A3C introduction

    转自https://zhuanlan.zhihu.com/p/25239682 过去的一段时间在深度强化学习领域投入了不少精力,工作中也在应用DRL解决业务问题.子曰:温故而知新,在进一步深入研究和应 ...

  6. jvm 堆

    1.堆内存线程共享,在虚拟机启动时创建. 2.几乎所有的对象实例都在堆上分配:栈中存放基本数据类型和堆中对象的引用. GC回收 程序计数器.虚拟机栈.本地方法栈随线程而生,随线程而灭.栈中的栈帧随着方 ...

  7. DevExpress v18.2版本亮点——Office File API 篇

    行业领先的.NET界面控件——DevExpress v18.2版本亮点详解,本文将介绍了DevExpress Office File API v18.2 的版本亮点,新版30天免费试用!点击下载> ...

  8. 048:ORM模型基本的增删改查操作

    ORM对数据库的增删改查基本操作: 创建模型如下: 基本的增删改查如下:

  9. 对postman的研究

    1.Postman可用作macOS,Windows和Linux操作系统的本机应用程序. 2.最常用的方法是GET,POST,PUT和DELETE.方法的名称是不言自明的.例如,GET使您可以从服务器检 ...

  10. vue中的v-model原理,与组件自定义v-model

    VUE中的v-model可以实现双向绑定,但是原理是什么呢?往下看看吧 根据官方文档的解释,v-model其实是一个语法糖,它会自动的在元素或者组件上面解析为 :value="" ...