Log4j日志输出方式配置文件log4j.properties用法个人见解

xiaoxiao2021-02-28  117

 日志级别大小: DEBUG < INFO < WARN < ERROR < FATAL

 

1、log4j.rootLogger 的 使用

#log4j.rootLogger 配置的是大于等于当前级别的日志信息的输出 #log4j.rootLogger 用法:(注意appenderName可以是一个或多个) #log4j.rootLogger = 日志级别,appenderName1,appenderName2,.... #log4j.appender.appenderName1定义的是日志的输出方式,有两种:一种是命令行输出或者叫控制台输出,另一种是文件方式保存 # 1)控制台输出则应该配置为org.apache.log4j.PatternLayout # 2)文本方式保存应该配置为org.apache.log4j.DailyRollingFileAppender # 3)也可以自定义 Appender类 #log4j.appender.appenderName1.layout.ConversionPattern 定义的是日志内容格式 #log4j.appender.appenderName1.file 定义了该日志文件的文件名称 #log4j.appender.appenderName1.DatePattern 定义了日志文件重新生成的时间间隔,如果设置到天,则每天重新生成一个新的日志文件。 # 旧的日志文件则以新的文件名保存,文件名称 = log4j.appender.appenderName1.file + log4j.appender.appenderName1.DatePattern #log4j.appender.appenderName1.Encoding 定义了编码格式 log4j.rootLogger = info,stdout,file log4j.appender.stdout=org.apache.log4j.ConsoleAppender log4j.appender.stdout.layout=org.apache.log4j.PatternLayout log4j.appender.stdout.layout.ConversionPattern=[%p][%d{yyyy-MM-dd HH:mm:ss}][%C{1}:%L] - %m%n log4j.appender.file = org.apache.log4j.DailyRollingFileAppender log4j.appender.file.file=d\:\\log\\info(+).log log4j.appender.file.DatePattern= '.'yyyy-MM-dd log4j.appender.file.layout=org.apache.log4j.PatternLayout log4j.appender.file.layout.ConversionPattern=[%p][%d{yyyy-MM-dd HH:mm:ss}][%C{1}:%L] - %m%n log4j.appender.file.Encoding=UTF-8

 

上述代码,将 INFO 、WARN 、 ERROR 、FATAL 这四个级别的日志信息在控制台打印出来,并且以文件的形式保存到 d:\log\info(+).log  

  

2、log4j.logger 用法如下

# 1)log4j.logger.包名 = 日志级别 , appenderName1,appenderName2,.... # 定义该包名下的所有类的日志输出 # 2)log4j.logger.类全名含包名 = 日志级别 , appenderName1,appenderName2,.... # 定义指定类的日志输出 # 3) log4j.logger.日志对象Logger命名名称 = 日志级别 , appenderName1,appenderName2,.... # 定义了某命名名称的日志的 输出,如: # log4j.logger.Log1 就是指定义通过 Logger.getLogger("Log1") 获取的日志对象的日志输出 #以log4j.logger.包名为例子 log4j.logger.edu.service.impl = error,service_stdout,service_logfile log4j.appender.service_stdout=org.apache.log4j.ConsoleAppender log4j.appender.service_stdout.layout=org.apache.log4j.PatternLayout log4j.appender.service_stdout.layout.ConversionPattern=[%p][%d{yyyy-MM-dd HH:mm:ss}][%C{1}:%L] - %m%n log4j.appender.service_logfile = org.apache.log4j.DailyRollingFileAppender log4j.appender.service_logfile.file=d:\\log\\service.log log4j.appender.service_logfile.DatePattern= '.'yyyy-MM-dd log4j.appender.service_logfile.layout=org.apache.log4j.PatternLayout log4j.appender.service_logfile.layout.ConversionPattern=[%p][%d{yyyy-MM-dd HH:mm:ss}][%C{1}:%L] - %m%n log4j.appender.service_logfile.Encoding=UTF-8

 

package edu.service.impl; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.InputStream; import java.util.Iterator; import java.util.List; import org.apache.commons.lang.RandomStringUtils; import org.apache.log4j.Logger; import org.apache.poi.hssf.usermodel.HSSFRow; import org.apache.poi.hssf.usermodel.HSSFSheet; import org.apache.poi.hssf.usermodel.HSSFWorkbook; import utils.StringUtils; import edu.dao.UserDao; import edu.po.User; import edu.service.UserService; import edu.vo.UserVO; public class UserServiceImpl implements UserService { private Logger logger = Logger.getLogger(UserServiceImpl.class); .....

 

通过上述代码的配置,则 private Logger logger = Logger.getLogger(UserServiceImpl.class);  这个日志对象的ERROR、FATAL信息就会在控制台输出并保存到d:\log\service.log 文件。

 

 

 

转载请注明原文地址: https://www.6miu.com/read-23724.html

最新回复(0)