log4j日志收集

1. log4j 是什么

1. 日志管理工具

  • log4j 是 Apache 的一个开源项目
    (官网 http://jakarta.apache.org/log4j),
  • 通过在项目中使用 Log4J,我们可以控制日志信息输出到控制台、文件、GUI 组件、甚至是数据库中。
  • 我们可以控制每一条日志的输出格式,通过定义日志的输出级别, 可以更灵活的控制日志的输出过程。方便项目的调试。

对应的slf4j,也是日志管理工具

一般将日志输出到文件。或者将日志输出到数据库,做成对应的日志管理系统。
方便对程序分析,做出改正。

2. 有哪些组成部分?

log4j 主要由 Loggers (日志记录器)、Appenders(输出端)
和 Layout(日志格式化器)组成。
其中 Loggers 控制日志的输出级别与日志是否输出;
Appenders 指定日志的输出方式(输出到控制台、文件等);
Layout 控制日志信息的输出格式。

3. 日志级别

  • OFF 最高日志级别,关闭所有日志
  • FATAL 将会导致应用程序退出的错误
  • ERROR 发生错误事件,但仍不影响系统的继续运行
  • WARN 警告,即潜在的错误情形
  • INFO 一般和在粗粒度级别上,强调应用程序的运行全程
  • DEBUG 一般用于细粒度级别上,对调试应用程序非常有帮助
  • ALL 最低等级,打开所有日志记录
  • 一般只使用4个级别,优先级从高到低为 ERROR > WARN > INFO > DEBUG
  • 注意,是error,只会记录error级别及fatal, off的错误

2. 输出端与日志格式化器

Appender(输出端)

Appender 用来指定日志输出到哪个地方,可以同时指定日志的输出目的地。Log4j 常用的输出目的地有以下几种
ConsoleAppender 将日志输出到控制台
FileAppender 将日志输出到文件中
DailyRollingFileAppender 将日志输出到一个日志文件,并且每天输出到一个新的文件
RollingFileAppender 将日志信息输出到一个日志文件,并且指定文件的尺寸,当文件大 小达到指定尺寸时,会自动把文件改名,同时产生一个新的文件
JDBCAppender 把日志信息保存到数据库中

Layout(日志格式化器)

HTMLLayout 格式化日志输出为HTML表格形式
SimpleLayout 简单的日志输出格式化,打印的日志格式为(info - message)
PatternLayout 最强大的格式化期,可以根据自定义格式输出日志,如果没有指定转换格式,就是用默认的转换格式

3. log4j.properties

在d盘创建log文件夹,日志会自动输出到log下

#总控制 日志级别 使用哪些方式输出。 以error级别,只会logger.error(e)输出
log4j.rootLogger = error,stdout,D,E,F

#将日志输出到控制台
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  

#输出至文件 级别 DEBUG
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender  
log4j.appender.D.File = D\://logs/log.log  
log4j.appender.D.Append = true  
log4j.appender.D.Threshold = DEBUG   
log4j.appender.D.layout = org.apache.log4j.PatternLayout  
log4j.appender.D.layout.ConversionPattern = %-d{
    
    yyyy-MM-dd HH\:mm\:ss}  [ %t\:%r ] - [ %p ] -[%l]  %m%n  

#输出至文件 级别 ERROR
log4j.appender.E = org.apache.log4j.DailyRollingFileAppender  
log4j.appender.E.File =D\://logs/error.log
log4j.appender.E.Append = true  
log4j.appender.E.Threshold = ERROR   
log4j.appender.E.layout = org.apache.log4j.PatternLayout  
log4j.appender.E.layout.ConversionPattern =%-d{
    
    yyyy-MM-dd HH\:mm\:ss}  [ %t\:%r ] - [ %p ] -[%l]  %m%n

#输出至html文件 
log4j.appender.F=org.apache.log4j.DailyRollingFileAppender
log4j.appender.F.layout=org.apache.log4j.HTMLLayout
log4j.appender.F.File=D\:\\logs\\index.html
log4j.appender.F.layout.ConversionPattern =%-d{
    
    yyyy-MM-dd HH\:mm\:ss}  [ %t\:%r ] - [ %p ] -[%l]  %m%n

占位符,格式化日志

%m   输出代码中指定的日志信息
%p    输出优先级,及 DEBUG、INFO 等
%n    换行符(Windows平台的换行符为 "\n",Unix 平台为 "\n")
%r     输出自应用启动到输出该 log 信息耗费的毫秒数
%c    输出打印语句所属的类的全名
%t     输出产生该日志的线程全名
%d    输出服务器当前时间,默认格式为 ISO8601,也可以在后面指定格式。如:%d{yyyy年MM月dd日 HH:mm:ss}
%l     输出日志时间发生的位置,包括类名、发生的线程,以及在代码中的行数,如:Test.main(Test.java:10)
%F    输出日志消息产生时所在的文件名称
%L    输出代码中的行号
%x    输出和当前线程相关的 NDC(嵌套诊断环境)

4. 使用

private static Logger logger = Logger.getLogger(StudentController.class);
@Controller
public class AuthorAction extends BaseAction{
    
    
	
	// 日志对象
	private static Logger logger = Logger.getLogger(AuthorAction.class);
	
	private AuthorService authorService;
	@Autowired
	public void setAuthorService(AuthorService authorService) {
    
    
		this.authorService = authorService;
	}
	
	//查询所有书籍
	public String findAuthor(){
    
    
		logger.info("查询所有书籍 start");
		
		try{
    
    
			List<Author> authorList = authorService.findAuthor();
			this.getRequest().setAttribute("authorList", authorList);
			SimpleDateFormat ft = new SimpleDateFormat("yyyy-MM-dd");
			System.out.println("查询所有书籍");
			
			int count = 1/0;
			
		} catch (Exception e) {
    
    
//			logger.info(e.getMessage()); // 记录普通信息,程序运行过程
//			logger.debug(e.getMessage()); // debug模式
//			logger.warn(e.getMessage()); // 警告
			//logger.error(e.getStackTrace()); // 错误
			logger.error(e+"--"+e.getStackTrace()[0].getLineNumber()); // 错误类,对应的行号
		}
		
		logger.info("查询所有书籍 end"); 
		
		return "authorList";
	}
	
}

猜你喜欢

转载自blog.csdn.net/qq_44783283/article/details/108943501