log4j.jar log4j.properties 配置与使用

一、配置log4j.properties

如下:

#配置根日志优先级,及输出位置
#语法:log4j.rootLogger = [debug],apppenderName1,appenderName2...
log4j.rootLogger = debug,stdout,D	

#上面定义了两个输出位置名:stdout与D,现分别配置:
#配置stdout为调试窗口输出:
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.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.FileAppender
log4j.appender.D.File=D:\\Program_software\\Apache7_0_75\\webapps\\testLog.log
log4j.appender.D.layout=org.apache.log4j.PatternLayout
log4j.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,这些参数是该应用的全局参数。


		webAppRootKey
		/
	
	
		log4jConfigLocation
		WEB-INF/log4j.properties
	
	
		log4jRefreshInterval
		60000
	
	
		org.springframework.web.util.Log4jConfigListener
	

说明:

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
















你可能感兴趣的:(工具使用,log4j)