专栏首页xingoo, 一个梦想做发明家的程序员Log4j官方文档翻译(八、文件输出)

Log4j官方文档翻译(八、文件输出)

使用org.apache.log4j.FileAppender可以把日志写到文件中:

FileAppender配置

  • immediateFlush 这个标志默认为true,是否每次有消息产生都自动flush到文件中
  • encoding 字符编码
  • threshold appender的阈值threshold
  • Filename 日志文件的名称
  • fileAppend 默认设置为true,所有的日志都输出到相同的文件
  • bufferedIO 是否启用缓冲区,默认是false
  • bufferSize 如果启用了缓冲区,设置缓冲区的大小。默认是8kb.

下面是log4j.properties中FileAppender的相关配置:

##### Define the root logger with appender filelog4j.rootLogger = DEBUG, FILE##### Define the file appenderlog4j.appender.FILE=org.apache.log4j.FileAppender##### Set the name of the filelog4j.appender.FILE.File=${log}/log.out##### Set the immediate flush to true (default)log4j.appender.FILE.ImmediateFlush=true##### Set the threshold to debug modelog4j.appender.FILE.Threshold=debug##### Set the append to false, overwritelog4j.appender.FILE.Append=false##### Define the layout for file appenderlog4j.appender.FILE.layout=org.apache.log4j.PatternLayoutlog4j.appender.FILE.layout.conversionPattern=%m%n

如果是配置XML的配置文件,可以参考如下:

<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd"> <log4j:configuration> <appender name="FILE" > <param name="file" value="${log}/log.out"/> <param name="immediateFlush" value="true"/> <param name="threshold" value="debug"/> <param name="append" value="false"/> <layout > <param name="conversionPattern" value="%m%n"/> </layout> </appender> <logger name="log4j.rootLogger" additivity="false"> <level value="DEBUG"/> <appender-ref ref="FILE"/> </logger> </log4j:configuration>

多文件输出——日志轮转

如果需要把日志文件写入到多个文件中,例如,按照文件的大小,到达一定的阈值后,就写入另一个文件。

那么你可以使用apache.log4j.RollingFileAppender类,它继承了FileAppender,并能设置一些属性达到上面的需求。

添加的属性如下:

  • maxFileSize 这是日志轮转的关键属性,设置了日志的大小阈值,默认是10MB
  • maxBackupIndex 这个属性设置了文件会被备份的数目,默认是1

log4j.properties的配置如下

##### Define the root logger with appender filelog4j.rootLogger = DEBUG, FILE##### Define the file appenderlog4j.appender.FILE=org.apache.log4j.RollingFileAppender##### Set the name of the filelog4j.appender.FILE.File=${log}/log.out##### Set the immediate flush to true (default)log4j.appender.FILE.ImmediateFlush=true##### Set the threshold to debug modelog4j.appender.FILE.Threshold=debug##### Set the append to false, should not overwritelog4j.appender.FILE.Append=true##### Set the maximum file size before rolloverlog4j.appender.FILE.MaxFileSize=5KB##### Set the the backup indexlog4j.appender.FILE.MaxBackupIndex=2##### Define the layout for file appenderlog4j.appender.FILE.layout=org.apache.log4j.PatternLayoutlog4j.appender.FILE.layout.conversionPattern=%m%n

如果你希望配置xml文件,那么只要把RollingFileAppender以及它的两个属性添加进去就可以了。

上面的文件中,最大的文件大小为5kb,当超过这个大小后,就会创建新的文件;然后这个文件被命名为log.1;同理,如果有log.2就会重命名为log.3。如果索引数目最多设置为5,并且已经存在了log.5,那么log.5会被直接删除。

多问键输出——日期轮转

如果想要每天更新一下日志文件,那么可以使用org.apache.log4j.DailyRollingFileAppender。

它增加的属性如下:

  • DatePattern 这个属性声明了命名规则,默认是每一天的半夜24点更新一次

这个属性可以按照下面的方式书写:

  • '.'yyyy-MM 在每个月刚开始的时候更新一次
  • '.'yyyy-MM-dd 每天半夜24点的时候更新
  • '.'yyyy-MM-dd-a 每天12点和24点更新
  • '.'yyyy-MM-dd-HH 每个小时更新一次
  • '.'yyyy-MM-dd-HH-mm 每分钟更新一次
  • '.'yyyy-ww 每周的第一天更新

log4j.properties的配置如下

##### Define the root logger with appender filelog4j.rootLogger = DEBUG, FILE##### Define the file appenderlog4j.appender.FILE=org.apache.log4j.DailyRollingFileAppender##### Set the name of the filelog4j.appender.FILE.File=${log}/log.out##### Set the immediate flush to true (default)log4j.appender.FILE.ImmediateFlush=true##### Set the threshold to debug modelog4j.appender.FILE.Threshold=debug##### Set the append to false, should not overwritelog4j.appender.FILE.Append=true##### Set the DatePatternlog4j.appender.FILE.DatePattern='.' yyyy-MM-dd-a##### Define the layout for file appenderlog4j.appender.FILE.layout=org.apache.log4j.PatternLayoutlog4j.appender.FILE.layout.conversionPattern=%m%n

同样,如果在xml中配置,添加相关的属性即可。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Log4j官方文档翻译(四、如何在java中输出日志消息)

    我们已经创建来配置文件,本章详细的介绍下如何生成调试信息,并把他们转化成文本文件。 基本的例子 下面就是创建的一个基本的例子: log4j.properties...

    用户1154259
  • Log4j官方文档翻译(九、输出到数据库)

    log4j提供了org.apache.log4j.JDBCAppender对象,可以把日志输出到特定的数据库。 常用的属性: bufferSize 设置buff...

    用户1154259
  • [logstash-input-log4j]插件使用详解

    Log4j插件可以通过log4j.jar获取Java日志,搭配Log4j的SocketAppender和SocketHubAppender使用,常用于简单的集...

    用户1154259
  • Linux系统如何做性能测试?

      1、登录Terminal,执行:cat /proc/cpuinfo,就会显示出主机的CPU详细参数,如内核、频率、型号等等,以下是我Linux 系统主机的C...

    小老鼠
  • 科比总得分超乔丹,八一八“小飞侠”与“乔帮主”数据故事

    12月15日,湖人客场对阵打森林狼,科比·布莱恩特在次节5分24秒得到本场第9分,生涯总得分也达到32293分,科比在自己职业生涯第19年,终于完成了对自己偶像...

    CSDN技术头条
  • LINUX系统性能调谐

    邓延军 (deng.yanjun@163.com), 硕士研究生, 西安电子科技大学软件工程研究所

    一见
  • js获取鼠标单击键

    利用OnMousedown和OnContextmenu添加鼠标左中右键单击的处理,返回event.button的值来判断是单击了哪个键。

    DougWang
  • 从游击队到正规军(二):马蜂窝旅游网的IM客户端架构演进和实践总结

    移动互联网技术改变了旅游的世界,这个领域过去沉重的信息分销成本被大大降低。用户与服务供应商之间、用户与用户之间的沟通路径逐渐打通,沟通的场景也在不断扩展。这促使...

    JackJiang
  • 视频传输延迟分析及解决方案:CMAF、LHLS

    使用在线流媒体平台做直播时,实时体验至关重要:看世界杯时,您还边正在聚精会神地盯着C罗的金刚腿等着罚球,隔壁老王就传出进球欢呼声,您肯定无比郁闷。视频播放领域的...

    用户1324186
  • RTSP协议网页无插件直播平台EasyNVR视频广场无法搜索纯数字关键词的通道,该如何解决的?

    最近改版的新版EasyNVR我们发现界面中仍然保留了“视频广场”的显示项,通过视频广场可以查看不同通道的最新视频快照信息,也可以通过搜索方式展现特定的视频通道快...

    EasyNVR

扫码关注云+社区

领取腾讯云代金券