log4j基本操作

原创
2016/11/03 16:26
阅读数 17

log4j基本操作

 1、导入log4j的jar包(log4j-1.2.17.jar)。

2、创建Logger对象

	//创建Logger对象
	public static final Logger logger = Logger.getLogger(UserDao.class);

3、编写相应的日志

		/**
		 * 可以为日志设定不同的级别,在log4j中
		 * debug<info<warn<error<fatal
		 */
		logger.debug("添加了用户信息");
		logger.info("添加了用户信息");
		logger.warn("添加了用户信息");
		logger.error("添加了用户信息");
		logger.fatal("添加了用户信息");

4、编写日志的配置文件,以此说明日志的显示方式和级别(在src中创建log4j.properties文件)。

    4.1、首先创建Appender

log4j.appender.stout=org.apache.log4j.ConsoleAppender

    创建了一个Appender名称叫做stout(自定义名称),使用的类型是ConsoleAppender。

    4.2、说明展示的布局

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

    说明Appender使用哪种布局来展示,常用的是PatternLayout。

    4.3、说明通过什么样的格式来完成展示(详细参数参见6)

log4j.appender.stout.layout.ConversionPattern=[%p](%l)-->%m(%d)%n

    使用的格式是[什么级别的日志](日志的发生地)-->日志信息(日志的时间)换行

5、在什么时候输出日志

#rootLogger的创建
log4j.rootLogger=DEBUG, stout

rootLogger是根目录的Logger,每一个项目的classpath就是根目录,只要运行到输出日志的位置,并且日志
的级别大于DEBUG就会输出。rootLogger表示的就是执行的任意一个类只要有大于DEBUG的日志就会输
出,会调用stout这个Appender输出。

6、日志输出格式的参数:

在配置文件中可以通过log4j.appender.A1.layout.ConversionPattern设置日志输出格式。 
参数: 
%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”输出日志信息换行 
可以在%与模式字符之间加上修饰符来控制其最小宽度、最大宽度、和文本的对齐方式。如: 
1)%20c:指定输出category的名称,最小的宽度是20,如果category的名称小于20的话,默认的情况下右对齐。 
2)%-20c:指定输出category的名称,最小的宽度是20,如果category的名称小于20的话,”-”号指定左对齐。 
3)%.30c:指定输出category的名称,最大的宽度是30,如果category的名称大于30的话,就会将左边多出的字符截掉,但小于30的话也不会有空格。 
4)%20.30c:如果category的名称小于20就补空格,并且右对齐,如果其名称长于30字符,就从左边交远销出的字符截掉。 

7、日志输出到指定文件中

    7.1、使用绝对路径

#使用FileAppender输出到文件中
#log4j.appender.fout=org.apache.log4j.FileAppender

#文件的位置,使用绝对路径在将来更改计算机的时候就可能找不到,所以一般建议使用相对路径
#log4j.appender.fout.file = d:/test/log/user.log

#创建了一个名称为test的logger,这是基于名称的访问,但是不建议使用
#log4j.logger.test = WARN, fout
//创建Logger对象,使用"test"表示会去找log4j.properties中的log4j.logger.test这个Appender
	//不建议使用基于名称的访问
//	public static final Logger logger = Logger.getLogger("test");

    7.2、使用相对路径

#使用相对路径有多种方法,常用的方法是将路径的值存储到System.setProperty中
#${LOG_DIR}就是System.setProperty()中设置的值,在web项目中可以直接在项目启动的时候进行设置
log4j.appender.fout.file = ${LOG_DIR}/user.log

log4j.appender.fout.layout=org.apache.log4j.PatternLayout
log4j.appender.fout.layout.ConversionPattern=[%p](%l)-->%m%n

#以下表示会在org.pm.service这个包中找只要通过Logger.getLogger(xx.class)注入的类
log4j.logger.org.pm.service = DEBUG,fout
	//创建Logger对象,使用"test"表示会去找log4j.properties中的log4j.logger.test这个Appender
	//不建议使用基于名称的访问
//	public static final Logger logger = Logger.getLogger("test");
	public static final Logger logger = Logger.getLogger(UserService.class);
		//将路径的值存储到System.setProperty中
        String url = UserService.class.getClassLoader().getResource("").getPath();
		url = url.replace("bin/", "log");
		System.setProperty("LOG_DIR", url);

    7.3、常用的配置

#常用的方式
log4j.appender.stout=org.apache.log4j.ConsoleAppender
log4j.appender.stout.layout=org.apache.log4j.PatternLayout
log4j.appender.stout.layout.ConversionPattern=[%p](%l)-->%m(%d)%n

#使用FileAppender输出到文件中
#log4j.appender.fout=org.apache.log4j.FileAppender

#基于日期的方式,需要设定相应的DatePattern,常用的方式
log4j.appender.fout=org.apache.log4j.DailyRollingFileAppender
log4j.appender.fout.DatePattern='.'yyyy-MM-dd

#基于文件大小的方式
#log4j.appender.fout=org.apache.log4j.RollingFileAppender
#log4j.appender.fout.MaximumFileSize = 200
#log4j.appender.fout.MaxBackupIndex = 100

#文件的位置,使用绝对路径在将来更改计算机的时候就可能找不到,所以一般建议使用相对路径
#log4j.appender.fout.file = d:/test/log/user.log

#常用的方式
#使用相对路径有多种方法,常用的方法是将路径的值存储到System.setProperty中
#${LOG_DIR}就是System.setProperty()中设置的值,在web项目中可以直接在项目启动的时候进行设置
log4j.appender.fout.file = ${LOG_DIR}/user.log

log4j.appender.fout.layout=org.apache.log4j.PatternLayout
log4j.appender.fout.layout.ConversionPattern=[%p](%l)-->%m%n

#rootLogger的创建
log4j.rootLogger=FATAL, stout
#创建了一个名称为test的logger,这是基于名称的访问,但是不建议使用
#log4j.logger.test = WARN, fout

#以下表示会在org.pm.service这个包中找只要通过Logger.getLogger(xx.class)注入的类
log4j.logger.org.pm.service = DEBUG,fout

8、实际应用(Hibernate日志输出)

### direct log messages to stdout ###
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n

### direct messages to file hibernate.log ###
#log4j.appender.file=org.apache.log4j.FileAppender
#log4j.appender.file.File=hibernate.log
#log4j.appender.file.layout=org.apache.log4j.PatternLayout
#log4j.appender.file.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n

### set log levels - for more verbose logging change 'info' to 'debug' ###

log4j.rootLogger=warn, stdout

#log4j.logger.org.hibernate=info
#log4j.logger.org.hibernate=debug

### log HQL query parser activity
#log4j.logger.org.hibernate.hql.ast.AST=debug

### log just the SQL
log4j.logger.org.hibernate.SQL=debug

### log JDBC bind parameters ###
#log4j.logger.org.hibernate.type=info
#log4j.logger.org.hibernate.type=debug

### log schema export/update ###
log4j.logger.org.hibernate.tool.hbm2ddl=debug

### log HQL parse trees
#log4j.logger.org.hibernate.hql=debug

### log cache activity ###
#log4j.logger.org.hibernate.cache=debug

### log transaction activity
#log4j.logger.org.hibernate.transaction=debug

### log JDBC resource acquisition
#log4j.logger.org.hibernate.jdbc=debug

### enable the following line if you want to track down connection ###
### leakages when using DriverManagerConnectionProvider ###
#log4j.logger.org.hibernate.connection.DriverManagerConnectionProvider=trace

 

展开阅读全文
打赏
0
1 收藏
分享
加载中
更多评论
打赏
0 评论
1 收藏
0
分享
OSCHINA
登录后可查看更多优质内容
返回顶部
顶部