`

log4j简介

    博客分类:
  • J2EE
 
阅读更多

1、 Log4j是什么?

Log4j简单来说就是用来记日志的,帮助程序猿调试和分析,他的作用是很大的,只是我们还没有加以利用,这里做一个简介,要了解详细信息请访问log4j官网

2、Log4j的概念

Log4j中有三个主要的组件,它们分别是 Logger、Appender和Layout。

  1. Log4j 允许开发人员定义多个Logger,每个Logger拥有自己的名字,Logger之间通过名字来表明隶属关系。有一个Logger称为Root,它永远 存在,且不能通过名字检索或引用,可以通过Logger.getRootLogger()方法获得,其它Logger通过 Logger.getLogger(String name)方法。
  2. Appender则是用来指明将所有的log信息存放到什么地方,Log4j中支持多种appender,如 console、files、GUI components、NT Event Loggers等,一个Logger可以拥有多个Appender,也就是你既可以将Log信息输出到屏幕,同时存储到一个文件中。
  3. Layout的作用是控制Log信息的输出方式,也就是格式化输出的信息。

3、Log4j的配置文件

虽然可以不用配置文件,而在程序中实现配置,但这种方法在如今的系统开发中显然是不可取的,能采用配置文件的地方一定一定要用配置文件。 Log4j支持两种格式的配置文件:XML格式和Java的property格式,如下:

log4j.rootLogger=debug,CONSOLE

log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n

log4j.appender.DEFAULT=org.apache.log4j.DailyRollingFileAppender 
log4j.appender.DEFAULT.DatePattern='.'yyyy-MM-dd
log4j.appender.DEFAULT.Append=true
log4j.appender.DEFAULT.File=${user.home}/logs/zsht-default.log
log4j.appender.DEFAULT.layout=org.apache.log4j.PatternLayout
log4j.appender.DEFAULT.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n

log4j.appender.REST=org.apache.log4j.DailyRollingFileAppender
log4j.appender.REST.DatePattern='.'yyyy-MM-dd
log4j.appender.REST.Append=true
log4j.appender.REST.File=${user.home}/logs/zsht-rest.log
log4j.appender.REST.layout=org.apache.log4j.PatternLayout
log4j.appender.REST.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n

# Sense
log4j.appender.SENSE=org.apache.log4j.DailyRollingFileAppender 
log4j.appender.SENSE.DatePattern='.'yyyy-MM-dd
log4j.appender.SENSE.Append=true
log4j.appender.SENSE.File=${user.home}/logs/sense.log
log4j.appender.SENSE.layout=org.apache.log4j.PatternLayout
log4j.appender.SENSE.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n

# CACHE
log4j.appender.CACHE=org.apache.log4j.DailyRollingFileAppender 
log4j.appender.CACHE.DatePattern='.'yyyy-MM-dd
log4j.appender.CACHE.Append=true
log4j.appender.CACHE.File=${user.home}/logs/cache.log
log4j.appender.CACHE.layout=org.apache.log4j.PatternLayout
log4j.appender.CACHE.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n

# SESSION
log4j.appender.SESSION=org.apache.log4j.DailyRollingFileAppender 
log4j.appender.SESSION.DatePattern='.'yyyy-MM-dd
log4j.appender.SESSION.Append=true
log4j.appender.SESSION.File=${user.home}/logs/session.log
log4j.appender.SESSION.layout=org.apache.log4j.PatternLayout
log4j.appender.SESSION.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n

log4j.logger.REST=INFO,REST
log4j.logger.org.jpxx.sense=INFO,SENSE
log4j.logger.org.jpxx.commons.cache=INFO,CACHE
log4j.logger.org.jpxx.commons.session=INFO,SESSION

设置root

格式为log4j.rootLogger=[level],appenderName, ...,其中level就是设置需要输出信息的级别(info,debug等),后面是appender,相当于指定日志信息输出到哪个地方,可以同时指 定多个目的地,如上述配置中的CONSOLE,DEFAULT都是。

设置appender

Appender配置日志的输出目的地

log4j.appender.DEFAULT=org.apache.log4j.DailyRollingFileAppender 
log4j.appender.DEFAULT.DatePattern='.'yyyy-MM-dd


第二天原文件的文件名改为xx.yyyy-MM-dd

Log4j提供的appender有以下几种:

org.apache.log4j.ConsoleAppender(控制台)
org.apache.log4j.FileAppender(文件)
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件)
org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生新文件)
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)
org.apache.log4j.jdbc.JDBCAppender(将日志信息存入数据库)


配置文件路径

log4j.appender.DEFAULT.File=${user.home}/logs/zsht-default.log
log4j.appender.DEFAULT.Append=true


Append=true表示不覆盖原文件,从末尾追加日志

${user.home}表示当前用户
配置日志信息的格式(布局)

log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout


Log4j提供的常用layout有以下几种:

org.apache.log4j.HTMLLayout(以HTML表格形式布局)
org.apache.log4j.PatternLayout(可以灵活地指定布局模式)
org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串)
org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)


使用PatternLayout布局比较灵活,可以使用配置

log4j.appender.CONSOLE.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n


来定义具体的输出形式,Log4J采用类似C语言中的printf函数的打印格式格式化日志信息
Log4j中常用的打印参数

%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS}
%c 输出所属的类目,通常就是所在类的全名 
%p 输出优先级,即DEBUG,INFO
%m 输出代码中指定的消息
%n 输出一个回车换行符,Windows平台为“\r\n”,Unix平台为“\n” 
%r 输出自应用启动到输出该log信息耗费的毫秒数 
%t 输出产生该日志事件的线程名 
%l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。

配置子日志属性项(可以不配置)

REST的日志同时会输出到rootLogger和REST

log4j.logger.REST=INFO,REST

不输出org.jpxx.sense的日志

log4j.logger.org.jpxx.sense=INFO,SENSE
log4j.additivity.org.jpxx.sense=false

4.项目须知(重要)

  1. log4j.properties文件的位置:在eclipse中位于web项目的src/log4j.properties,在生产服务器上位于 tomcat目录/webapps/ROOT/WEB-INF/classes/log4j.properties
  2. 日志文件的位置(.log文件):通过log4j.appender.appenderName.File这个属性配置,appenderName是自己命名的,${user.home}表示当前用户,不知道的可以通过代码
    System.getProperty("user.home");
    

    获得数据
  3. 如果部署环境是windows系统,日志不能输出在c盘,除非系统只有一个盘符c盘。日志文件会不断积累,如果没有监控,当日志文件占满整个c盘,系统将会崩溃
  4. 生产发布的应用日志的等级为info,不能为debug,debug主要用于程序猿调试使用,如果生产使用debug等级,日志量会翻倍,更容易占满空间
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics