LOG4J 入门

为什么Tomcat下面会生成TXT日志?

 

 

认识LOG4J

 

Apache开放源代码  控制台 文件 控制输出格式  日志生成过程  配置文件配置

 

 

LOG4J配置步骤

 

1:加入JAR

2CLASSPATH下建立log4j.properties

3:根据自己需要,修改log4j.properties属性配置

4:代码中控制日志生成

 

LOG4J基本配置

log4j.rootLogger=OFF

log4j.rootLogger=error,R

#log4j.category.com.layer=warn,A1,R

#log4j.appender.A1=org.apache.log4j.ConsoleAppender

#log4j.appender.A1.layout=org.apache.log4j.PatternLayout

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

log4j.appender.R=org.apache.log4j.DailyRollingFileAppender

#log4j.appender.R.File=D:/log/log.txt

log4j.appender.R.File=../logs/error.log

#log4j.appender.R.MaxFileSize=500KB

#log4j.appender.R.MaxBackupIndex=1

#log4j.appender.R.layout=org.apache.log4j.HTMLLayout

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

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

 

 

 

 

 

 

 

 

 

 

 

 

log4j.rootLogger=error,R

OFF 是日志记录的优先级,分为OFFFATALERRORWARNINFODEBUGALL或者自定义的级别。Log4j建议只使用四个级别,优先级从高到低分别是ERRORWARNINFODEBUG。比如在这里定义了INFO级别,只有等于及高于这个级别的才进行处理,则应用程序中所有DEBUG级别的日志信息将不被打印出来。ALL:打印所有的日志,OFF:关闭所有的日志输出。

 

 

log4j.appender.R=org.apache.log4j.DailyRollingFileAppender

配置日志信息输出目的地 Appender

org.apache.log4j.ConsoleAppender(控制台),

org.apache.log4j.FileAppender(文件),

org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件),

org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件)

可通过log4j.appender.R.MaxFileSize=100KB设置文件大小,还可通过log4j.appender.R.MaxBackupIndex=1设置为保存一个备份文件

 

 

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

配置日志信息的格式(布局)Layout

org.apache.log4j.HTMLLayout(以HTML表格形式布局),

org.apache.log4j.PatternLayout(可以灵活地指定布局模式),

org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),

org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)

 

 

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

格式化日志信息

  Log4J采用类似C语言中的printf函数的打印格式格式化日志信息,打印参数如下:

  %m 输出代码中指定的消息

  %p 输出优先级,即DEBUGINFOWARNERRORFATAL

  %r 输出自应用启动到输出该log信息耗费的毫秒数

  %c 输出所属的类目,通常就是所在类的全名

  %t 输出产生该日志事件的线程名

  %n 输出一个回车换行符,Windows平台为“rn”Unix平台为“n”

  %d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyyy MMM dd HH:mm:ss,SSS},输出类似:20021018 221028921

%l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。

 

 

 

Spring整合log4j

<listener>
    <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
 </listener>

<context-param>
    <param-name>log4jConfigLocation</param-name>
    <param-value>/WEB-INF/log4j.xml</param-value>
 </context-param>

 

   

 

 

其他参考:

 

http://blog.csdn.net/jemmy/archive/2007/11/16/1889114.aspx

http://baike.baidu.com/view/25347.htm#sub25347

LOG4J官方文档  F:/学习资料/学习文档/开源文档/apache-log4j-1.2.16

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章