1、 Log4j是什么?
Log4j简单来说就是用来记日志的,帮助程序猿调试和分析,他的作用是很大的,只是我们还没有加以利用,这里做一个简介,要了解详细信息请访问log4j官网。
2、Log4j的概念
Log4j中有三个主要的组件,它们分别是 Logger、Appender和Layout。
- Log4j 允许开发人员定义多个Logger,每个Logger拥有自己的名字,Logger之间通过名字来表明隶属关系。有一个Logger称为Root,它永远 存在,且不能通过名字检索或引用,可以通过Logger.getRootLogger()方法获得,其它Logger通过 Logger.getLogger(String name)方法。
- Appender则是用来指明将所有的log信息存放到什么地方,Log4j中支持多种appender,如 console、files、GUI components、NT Event Loggers等,一个Logger可以拥有多个Appender,也就是你既可以将Log信息输出到屏幕,同时存储到一个文件中。
- 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.项目须知(重要)
- log4j.properties文件的位置:在eclipse中位于web项目的src/log4j.properties,在生产服务器上位于 tomcat目录/webapps/ROOT/WEB-INF/classes/log4j.properties
- 日志文件的位置(.log文件):通过log4j.appender.appenderName.File这个属性配置,appenderName是自己命名的,${user.home}表示当前用户,不知道的可以通过代码
System.getProperty("user.home");
获得数据 - 如果部署环境是windows系统,日志不能输出在c盘,除非系统只有一个盘符c盘。日志文件会不断积累,如果没有监控,当日志文件占满整个c盘,系统将会崩溃
- 生产发布的应用日志的等级为info,不能为debug,debug主要用于程序猿调试使用,如果生产使用debug等级,日志量会翻倍,更容易占满空间