其中TestLog4j.java如下:

  1. package cn.zhoucy.test;
  2. import org.apache.log4j.Logger;
  3. public class TestLog4j {
  4. private static Logger logger=Logger.getLogger(TestLog4j.class); // 获取logger实例
  5. public static void main(String[] args) {
  6. logger.debug("调试debug信息");
  7. logger.info("普通Info信息");
  8. logger.warn("警告warn信息");
  9. logger.error("error信息");
  10. logger.fatal("严重错误fatal信息");
  11. }
  12. }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18

log4j.properties如下:

  1. log4j.rootLogger=DEBUG, Console ,File ,DailyRollingFile ,RollingFile
  2. #Console
  3. log4j.appender.Console=org.apache.log4j.ConsoleAppender
  4. log4j.appender.Console.layout=org.apache.log4j.PatternLayout
  5. log4j.appender.Console.layout.ConversionPattern=%d [%t] %-5p [%c] - %m%n
  6. #File
  7. log4j.appender.File = org.apache.log4j.FileAppender
  8. log4j.appender.File.File = E://File.log
  9. log4j.appender.File.layout = org.apache.log4j.PatternLayout
  10. log4j.appender.File.layout.ConversionPattern =%d [%t] %-5p [%c] - %m%n
  11. #DailyRollingFile
  12. log4j.appender.DailyRollingFile = org.apache.log4j.DailyRollingFileAppender
  13. log4j.appender.DailyRollingFile.File = E://DailyRollingFile.log
  14. log4j.appender.DailyRollingFile.layout = org.apache.log4j.PatternLayout
  15. log4j.appender.DailyRollingFile.layout.ConversionPattern =%d [%t] %-5p [%c] - %m%n
  16. #RollingFile
  17. log4j.appender.RollingFile = org.apache.log4j.RollingFileAppender
  18. log4j.appender.RollingFile.File = E://RollingFile.log
  19. log4j.appender.RollingFile.MaxFileSize=1KB
  20. log4j.appender.RollingFile.MaxBackupIndex=3
  21. log4j.appender.RollingFile.layout = org.apache.log4j.PatternLayout
  22. log4j.appender.RollingFile.layout.ConversionPattern =%d [%t] %-5p [%c] - %m%n
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26

由配置文件:Console 和File是常规的控制台和文件输出,而DailyRollingFile 和RollingFile分别是按天生成,和按日志文件指定大小生成文件。
运行后,控制台输出如下:

查看E盘根目录(我运行了7次程序,期间为了演示每天生成,改过两次电脑日期):

这里的File.log就是普通的输出,追加的方式。

2、每天生成一个日志文件

首先来看下配置:

  1. #DailyRollingFile
  2. log4j.appender.DailyRollingFile = org.apache.log4j.DailyRollingFileAppender
  3. log4j.appender.DailyRollingFile.File = E://DailyRollingFile.log
  4. log4j.appender.DailyRollingFile.layout = org.apache.log4j.PatternLayout
  5. log4j.appender.DailyRollingFile.layout.ConversionPattern =%d [%t] %-5p [%c] - %m%n
  • 1
  • 2
  • 3
  • 4
  • 5

关键配置就两行:
第1行:

  1. log4j.appender.DailyRollingFile = org.apache.log4j.DailyRollingFileAppender
  • 1

就表明是每天生成一个日志文件。

第2行:

  1. log4j.appender.DailyRollingFile.File = E://DailyRollingFile.log
  • 1

表明生成的日志文件名称,不过要注意,这里表示的是当天的文件名字,历史文件会以日期结尾。
最后两行在上一篇Log4j使用笔记(一)讲过,指明输出格式的。

3、按指定大小生成文件

有的时候,会需要指定文件大小,比如说,日志文件生成到了1M,就新生成一个日志文件,同时可以指定一共可以生成的最大文件数。配置文件如下:

  1. #RollingFile
  2. log4j.appender.RollingFile = org.apache.log4j.RollingFileAppender
  3. log4j.appender.RollingFile.File = E://RollingFile.log
  4. log4j.appender.RollingFile.MaxFileSize=1KB
  5. log4j.appender.RollingFile.MaxBackupIndex=3
  6. log4j.appender.RollingFile.layout = org.apache.log4j.PatternLayout
  7. log4j.appender.RollingFile.layout.ConversionPattern =%d [%t] %-5p [%c] - %m%n
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

关键的就是第3行和第4行:

  1. log4j.appender.RollingFile.MaxFileSize=1KB
  2. log4j.appender.RollingFile.MaxBackupIndex=3
  • 1
  • 2

表示的是,每个生成的日志最大是1KB,允许生成的最多文件数量是3,即是文件数量达到上限3个以后,则覆盖之前的文件。

附:log4j-1.2.17下载地址http://download.csdn.net/detail/theblackbeard/9820176

Log4j使用笔记:每天生成一个日志文件、按日志大小生成文件的更多相关文章

  1. 利用Matlab生成一个网格化的三维球面(生成直角坐标)

    利用Matlab生成一个网格化的三维球面,分别对径向方向.经度方向和纬度方向进行网格化,代码如下: %生成一个笛卡尔坐标系下球面网格的x,y,z坐标 %r为球面距离 %nJingdu,nWeidu分别 ...

  2. python基础一 ------利用生成器生成一个可迭代对象

    #利用生成器生成一个可迭代对象#需求:生成可迭代对象,输出指定范围内的素数,利用生成器产生一个可迭代对象#生成器:本身是可迭代的,只是 yield 好比return返回,yield返回后函数冻结状态, ...

  3. mysql之 日志体系(错误日志、查询日志、二进制日志、事务日志、中继日志)

    一. mysql错误日志:错误日志记录的事件:a).服务器启动关闭过程中的信息b).服务器运行过程中的错误信息c).事件调试器运行一个事件时间生的信息d).在从服务器上启动从服务器进程时产生的信息lo ...

  4. java应用测试报告生成(二):利用ant的build.xml生成测试报告

    1.将写好的项目导出 在工程下会生成一个build.xml的蚂蚁图标的文件. 2.右击该文件,选择run as Ant build 其中的测试目录是可以选择的,如果涉及到顺序也可以调整顺序 3.执行后 ...

  5. 在Linux系统下限制指定目录的大小以及文件/文件夹数量

    背景说明 在Linux操作系统下有时需要限制一个指定文件夹的大小和文件夹内可存储的文件数量,有可能是出于安全的考量或者定制化的配置,这里我们提供了一种方案:用dd创建一个空的img镜像,进行格式化的配 ...

  6. Linux_解决nohup命令生成的多余的大日志文件

    解决nohup命令生成的多余的大日志文件 经常使用命令 nohup /usr/bin/php /srv/www/update.php & 可以让它在后台安静的进行,但是有一个烦恼就是,它会生成 ...

  7. (Unity)Unity自定义Debug日志文件,利用VS生成Dll文件并使用Dotfuscated进展混淆,避免被反编译

    Unity自定义Debug日志文件,利用VS生成Dll文件并使用Dotfuscated进行混淆,避免被反编译. 1.打开VS,博主所用版本是Visual Studio 2013. 2.新建一个VC项目 ...

  8. log4j.properties配置与将异常输出到Log日志文件实例

    将异常输出到 log日志文件 实际项目中的使用: <dependencies> <dependency> <groupId>org.slf4j</groupI ...

  9. log4j中怎样将信息写入到不同的日志文件

    log4j中怎样将信息写入到不同的日志文件 有没有想过为什么我们用:Logger logger = Logger.getLogger(ABC.class) ;来得到 logger? 不想只看人家的 d ...

随机推荐

  1. css控制table间距

    border-collapse: separate;border-spacing: 20px 30px; /* 水平间距 垂直间距 */

  2. JS学习笔记Day26

    一.什么是设计模式? (一)设计模式(Design Pattern)是一套被反复使用.多数人知晓的.经过分类的.代码设计经验的总结. 二.单例模式 (一) 概念:单个实例,只有一个对象,多次创建,返回 ...

  3. 帕斯卡(pascal)命名法:

    帕斯卡(pascal)命名法: 与骆驼命名法类似.只不过骆驼命名法是首字母小写,而帕斯卡命名法是首字母大写 如:public void DisplayInfo(); string UserName; ...

  4. 强连通分量(Tarjan)

    //P2002解题思路: //先求SCC,缩点后,转换为DAG(有向无环图) //在DAG上统计入度为0的scc数量即可 //Tarjan时间复杂度:O(N+E),每个点和每条边刚好被访问一次,在空间 ...

  5. JavaScript之Map对象

    前言 工欲善其事,必先利其器.这是一款以前在前端项目中没有使用过的.有趣的对象,咱来看看如何使用~ 并非arrayObj.map(function) //arrayObj.map与arrayObj.f ...

  6. jenkins+supervisor实现django项目的自动部署(ubuntu)

    没有安装supervisor的话首先安装supervisor, apt install upservisor 安装supervisor大概率会出现问题,不推荐,最好是用pip 安装, 注意python ...

  7. python3: 自动化测试框架pytest

    最近在学习web自动化,所以在这里总结一下pytest框架. 其实pytest 和 unittest 都是自动化测试框架,但是pytest更好用一些,有以下几个优点:1)可以根据标签执行用例:2)?? ...

  8. vueSSR全栈(项目实战 mac)

    1.准备安装及指定版本 参考安装类中的 安装部分(node,npm,webpack) nuxt 官网下载nuxt脚手架(可以自定义版本) 需要下载MongoDB  redis 以及数据库可视化工具 具 ...

  9. STM32 USB 鼠标+键盘 串口控制

    *MOS0101000000# 鼠标左键按下 *MOS0102000000# 鼠标右键按下 *MOS0103000000# 鼠标中键按下 *MOS0100000000# 鼠标抬起 *MOS01000a ...

  10. Java数组的声明和遍历

    Java 数组 数组对于每一门编程语言来说都是重要的数据结构之一,当然不同语言对数组的实现及处理也不尽相同. Java 语言中提供的数组是用来存储固定大小的同类型元素. 你可以声明一个数组变量,如 n ...