log4j - 日记输出工具 的使用配置简洁实例

log4j - 日志输出工具 的使用配置简洁实例

实测,log4j 比 system.out.println 的性能好很多,尤其是大量输出语句时。

--------------------------------------------------------------

下载地址:

当前版本,2.0 beta3

jar :http://www.apache.org/dyn/closer.cgi/logging/log4j/2.0-beta3/apache-log4j-2.0-beta3-bin.zip

src:http://mirror.bit.edu.cn/apache/logging/log4j/2.0-beta3/apache-log4j-2.0-beta3-src.zip

实例版本:

jar :http://archive.apache.org/dist/logging/log4j/1.2.17/log4j-1.2.17.jar

src:http://archive.apache.org/dist/logging/log4j/1.2.17/log4j-1.2.17-sources.jar

--------------------------------------------------------------

实例开始(示例版本:1.2.17):

一、配置文件 log4j.properties

#log4j.rootLogger,第一个参数标示日志记录的优先级,只有等于、大于这个级别的日志才会被输出。
#log4j的日志的级别共有以下几种:OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL,
#但是我们一般只是用ERROR、WARN、INFO、DEBUG这四种(这里按照从高到低给出)。
log4j.rootLogger=DEBUG,console 

#将日志输出到控制台 
log4j.appender.console=org.apache.log4j.ConsoleAppender
#日志输出的信息布局
log4j.appender.console.layout=org.apache.log4j.PatternLayout
log4j.appender.console.Target=System.out 
#日志输出格式:%d{时间格式},%c 类路径,%n换行,%m 打印信息
#中文需 转为 unicode 
#log4j.appender.console.layout.ConversionPattern=%n[\u65F6\u95F4] %d{yyyy-MM-dd HH\:mm\:ss}  [\u8DEF\u5F84] %c  %n[\u4FE1\u606F] %m%n
log4j.appender.console.layout.ConversionPattern=%n[\u65F6\u95F4] %d{yyyy-MM-dd HH\:mm\:ss}   [\u4FE1\u606F] %m 

二、web工程部署使用

主要方式1、 log4j.properties 放在src下

			String class_path =  getClass().getResource("/").getPath();
			PropertyConfigurator.configure(class_path+"log4j.properties");//获取 log4j 配置文件
			Logger logger = Logger.getLogger(Phrase_wordsServlet.class ); //获取log4j的实例,Phrase_wordsServlet是当前java文件的名字
			logger.debug(">>----------已删除用户:"+u_id_delete); 

主要方式2、 log4j.properties 放在lib里面 (跟 log4j.jar 包同级 )

		String rootdir=System.getProperty("user.dir");//获取 工程根路径
		PropertyConfigurator.configure(rootdir+"\\WebRoot\\WEB-INF\\lib\\log4j.properties");//获取 log4j 配置文件
		//PropertyConfigurator.configure("C:\MyEclipse9\Workspaces\finance\WebRoot\WEB-INF\lib\log4j.properties"); 
		Logger logger = Logger.getLogger(Logger_Test.class ); //获取log4j的实例
	        logger.debug("控制台调试信息--debug ");//7


--------------------------------------------------------------

附件:unicode 和中文 互转工具  (log4j.properties配置文件里面  “\u65F6\u95F4” 表示“时间”)