log4j.jar log4j.properties 配置与使用

来源:互联网 发布:广州淘宝拍摄基地在哪 编辑:程序博客网 时间:2024/05/14 06:46

一、配置log4j.properties

如下:

#配置根日志优先级,及输出位置#语法:log4j.rootLogger = [debug],apppenderName1,appenderName2...log4j.rootLogger = debug,stdout,D#上面定义了两个输出位置名:stdout与D,现分别配置:#配置stdout为调试窗口输出:log4j.appender.stdout = org.apache.log4j.ConsoleAppenderlog4j.appender.stdout.Target=System.out#指定了一个模式表达式的布局log4j.appender.stdout.layout=org.apache.log4j.PatternLayout#设置该模式表达式log4j.appender.stdout.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n#说明:#[%-5p]:%p设置输出日志优先级,'-'表示左对齐,5表示日志优先级所占字符个数的宽度,取5是为了保持一致。如:[DEBUG]#%d{yyyy-MM-dd HH:mm:ss,SSS},指定了打印日志时间与时间格式,SSS表示?#%l: 输出日志事件的发生位置,见第四部分。%n,输出换行符。%m,输出日志事件发生的方法名。#配置D为输出日志到文件:log4j.appender.D=org.apache.log4j.FileAppenderlog4j.appender.D.File=D:\\Program_software\\Apache7_0_75\\webapps\\testLog.loglog4j.appender.D.layout=org.apache.log4j.PatternLayoutlog4j.appender.D.layout.ConversionPattern=[%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n####################################################################———————————配置详细说明,共四部分——————————##一、配置log4j.rootLogger#语法:log4j.rootLogger = [debug],apppenderName1,appenderName2...#如:log4j.rootLogger = debug,stdout#二、配置Appeder——输出位置#语法:log4j.appender.appenderName = fully.qualified.name.of.appender.class#完全合法的appenderName 有几类选择#1、控制台:org.apache.log4j.ConsoleAppender#对应选项:#Threshold=WARN:指定日志消息的输出最低层次#ImmediateFlush=true:默认日志立即打印#Target=System.err:默认情况下使用System.out 输出控制台#2、文件:org.apache.log4j.FileAppender#对应选项:#Threshold=WARN:指定日志消息输出最低层次#ImmediateFlush=true:默认日志立即打印#File=mylog.txt:指定输出路径,可以是任何路径#Append=false:默认值是true,为false则覆盖#3、周期产生日志文件:org.apache.log4j.DailyRollingFileAppender#对应选项:#Threshold=WARN:指定日志消息输出最低层次#ImmediateFlush=true:默认日志立即打印#File=a.log:指定消息输出到a.log文件,默认是从web服务器的根路径开始#Append=false:默认为true#DatePattern='.'yyyy-ww:每周滚动一次文件,即每周产生一个新的文件。#也可指定周期:#'.'yyyy-MM:每月#'.'yyyy-ww:每周#'.'yyyy-MM-dd:每天#'.'yyyy-MM-dd-a:每天两次#'.'yyyy-MM-dd-HH:每小时#'.'yyyy-MM-dd-HH-mm:每分钟#4、指定文件尺寸大小产生日志文件:org.apache.log4j.RollingFileAppender#对应选项:#Threshold=WARN:指定日志消息输出最低层次#ImmediateFlush=true:默认日志立即打印#File=a.log:指定日志文件#Append=false:默认为true#MaxFileSize=100KB:单位可以是KB|MB|GB,日志文件达到最大时,将会自动滚动,即将原来的内容移到mylog.log.1文件#MaxBackupIndex=2:指定可以产生滚动文件的最大数#5、将日志以流格式发送到任意指定的地方:org.apache.log4j.WriterAppender#例如:#log4j.appender.R=org.apache.log4j.DailyRollingFileAppender  #log4j.appender.R.File=D:\\eclipsespace\\testSSH\\WebContent\\WEB-INF\\testlog.log #三、配置日志信息的格式布局(layout)#layout负责格式化Appender 的输出#语法:#log4j.appender.appenderName.layout=fully.qualified.name.of.layout.class#有效的layout类名字有以下几种:#1、org.apache.log4j.HTMLLayout(以HTML表格形式布局)  #该选项有以下几种:  #LocationInfo=true:默认值是false,输出java文件名称和行号  #Title=my app file: 默认值是 Log4J Log Messages.  #2、org.apache.log4j.PatternLayout(可以灵活地指定布局模式)  #该选项有以下几种:  #ConversionPattern=%m%n :指定怎样格式化指定的消息  #其中%m%n等符号所代表的含义如下:  (有问题,暂不管)#-X号: X信息输出时左对齐;  #%p: 输出日志信息优先级,即DEBUG,INFO,WARN,ERROR,FATAL,  #%d: 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921  #%r: 输出自应用启动到输出该log信息耗费的毫秒数  #%c: 输出日志信息所属的类目,通常就是所在类的全名  #%t: 输出产生该日志事件的线程名  #%l: 输出日志事件的发生位置,相当于%C.%M(%F:%L)的组合,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main(TestLog4.java:10)  #%x: 输出和当前线程相关联的NDC(嵌套诊断环境),尤其用到像java servlets这样的多客户多线程的应用中。  #%%: 输出一个"%"字符  #%F: 输出日志消息产生时所在的文件名称  #%L: 输出代码中的行号  #%m: 输出代码中指定的消息,产生的日志具体信息  #%n: 输出一个回车换行符,Windows平台为"\r\n",Unix平台为"\n"输出日志信息换行  #可以在%与模式字符之间加上修饰符来控制其最小宽度、最大宽度、和文本的对齐方式。如:  #%20c:指定输出category的名称,最小的宽度是20,如果category的名称小于20的话,默认的情况下右对齐。  #%-20c:指定输出category的名称,最小的宽度是20,如果category的名称小于20的话,"-"号指定左对齐。  #%.30c:指定输出category的名称,最大的宽度是30,如果category的名称大于30的话,就会将左边多出的字符截掉,但小于30的话也不会有空格。  #%20.30c:如果category的名称小于20就补空格,并且右对齐,如果其名称长于30字符,就从左边交远销出的字符截掉。  #  如:%-4r %-5p %d{yyyy-MM-dd HH:mm:ssS} %c %m%n  [TEST] %p [%t] %C.%M(%L) | %m%n  #3、org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串)  #4、org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)  #四、其他#指定包名下的日志级别#语法:log4j.logger.包名=日志级别#如:#log4j.logger.com.neusoft =DEBUG  #指定com.neusoft包下的所有类的等级为DEBUG。 #log4j.logger.com.opensymphony.oscache=ERROR  #log4j.logger.net.sf.navigator=ERROR  #这两句是把这两个包下出现的错误的等级设为ERROR,如果项目中没有配置EHCache,则不需要这两句。   #log4j.logger.org.apache.commons=ERROR  #log4j.logger.org.apache.struts=WARN  #这两句是struts的包。  



说明:

1、前提是有commons-logging与 log4j 两个jar 包,这是常用包,建议放在服务器的lib 目录下。

2、日志路径好像只能为绝对路径,且注意格式!如:

D:\\Program_software\\Apache7_0_75\\webapps\\testLog.log

3、log4j.properties 放在类路径下(即src目录下雨包名同级)才能被服务器自动加载,当然也可以在web.xml 中指定放在WEB-INF下,见第二部分。



二、web.xml 中配置log4j.properties 的位置

在web.xml 中指定几个context-param,这些参数是该应用的全局参数。

<context-param><param-name>webAppRootKey</param-name><param-value>/</param-value><!--把项目发布路径的根路径映射为/--></context-param><context-param><param-name>log4jConfigLocation</param-name><param-value>WEB-INF/log4j.properties</param-value></context-param><context-param><param-name>log4jRefreshInterval</param-name><param-value>60000</param-value></context-param><listener><listener-class>org.springframework.web.util.Log4jConfigListener</listener-class></listener>

说明:

1、webAppRootKey 参数将项目发布根路径映射为一个自己指定的路径,如上面的设置会在启动日志中有体现:

信息: Set web app root system property: '/' = [D:\Program_software\Apache7_0_75\webapps\JWebSpringMVC2_5\]

设置此参数的目的是想在properties 中使用并将日志文件也定位到项目发布目录的WEB-INF/目录下,即通过相对方式,而非绝对,但未成功。

2、log4jConfigLocation 参数将引导tomcat 从WEB-INF/log4j.properties 中读取Log的配置。

3、需要配置监听器bean:org.sringframework.web.util.Log4jConfigListener



三、java 代码中使用Log 对象

若在tomcat lib目录中存放了两个jar 包,则可直接在项目中使用,在项目中配置log4j.proterties 并使用即可,否则需单独导包。

java 中使用Log 对象打日志:

Log logger=LogFactory.getLog("runLogger");Log interfaceLog=LogFactory.getLog("interfaceLogger");logger.error("测试LogFactory获得的runLogger");interfaceLog.error("interfaceLogger");

暂时未了解getLog 的参数的含义。

日志窗口:

[ERROR] 2017-04-21 00:16:30,793 method:com.milan.actions.HelloWorldAction.handleRequest(HelloWorldAction.java:24)测试LogFactory获得的runLogger[ERROR] 2017-04-21 00:16:30,793 method:com.milan.actions.HelloWorldAction.handleRequest(HelloWorldAction.java:25)interfaceLogger


参考:http://www.jb51.net/article/74477.htm
















0 0
原创粉丝点击