博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
log4j.properties 日志文件的详细配置说明
阅读量:4626 次
发布时间:2019-06-09

本文共 2189 字,大约阅读时间需要 7 分钟。

一、在一个web 项目中,使用tomcat 启动通常会在控制台输出出现一个警告信息:

通常为未添加 log4j.properties文件的原因。

 

二、下面以一个普通的maven项目为例说明一下

1. 在maven项目的配置文件pom.xml中已经有日志文件的配置选项,如果需要使用,记得配置进去。

1         
2
3
org.slf4j
4
slf4j-api
5
${org.slf4j.version}
6
7
8
org.slf4j
9
slf4j-log4j12
10
${org.slf4j.version}
11
runtime
12

2. 一般是在resources资源文件夹下添加 log4j.properties 配置文件。

log4j.properties 内容

#日志框架

#最早是System.out.print

#org.apache.log4j.Logger

#org.apache.commons.logging.Log

#java.util.logging.Logger

#org.slf4j.Logger 面向接口编程,选择实现(选择都使用这个)

#日志等级

#TRACE:详细等级,堆栈信息

#debug:类似于System.out.print

#info:类似于Hibernate的show_sql

#warn:不影响运行, 只是提示

#error:出现异常

#全局日志等级配置,输出位置

log4j.rootLogger=error, stdout,logfile

#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=%d %p [%c]:%L - %m%n

#文件路径输出

log4j.appender.logfile=org.apache.log4j.RollingFileAppender

#默认输出到tomcat的根路径或者运行测试工程的根路径

log4j.appender.logfile.File=pss.log

log4j.appender.logfile.MaxFileSize=512KB

# Keep three backup files.

log4j.appender.logfile.MaxBackupIndex=3

# Pattern to output: date priority [category] - message

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

log4j.appender.logfile.layout.ConversionPattern=%d %p [%c] - %m%n

#局部日志等级:就近原则

#log4j.logger.固定,后面添加想那个包使用不一样的日志等级

#log4j.logger.cn.itsource.pss=debug

三、补充

关于log4j日志文件的作用:

  在编程时经常不可避免地要使用到System.out.println() 语句输出日志信息,而且往往会有一些判断,

  比如: if(condition) { System.out.println("some information.") ; }  

  这些判断造成正常的程序逻辑中混杂了大量的输出语句。而在开发阶段写下的这些判断仅为了调试的语句,在开发完成时需要查找并移除。

  部署运行后,尤其是在一些企业应用系统中,还经常需要进一步调试,这时就遇到了更大的麻烦。所以,我们需要一套完备的、灵活的、可配置的日志工具.

所以, log4J就是优秀的选择。

 

Logger ----- 在执行应用程序时,接收日志语句生成的日志请求。

Appender -- 管理日志语句的输出结果。

Layout ----- 用于指定 appender 将日志语句写入日志目的地所采用的格式。

转载于:https://www.cnblogs.com/applerosa/p/5946739.html

你可能感兴趣的文章
计算机网络中的TCP/IP模型
查看>>
spring mvc 自定义Handlermapping
查看>>
JS验证密码安全级别
查看>>
Cookie是可以覆盖的,如果重复写入同名的Cookie,那么将会覆盖之前的Cookie。
查看>>
Django Models的数据类型
查看>>
博客之初体验-----python初了解
查看>>
jquery.fileupload插件 ie9下不支持上传
查看>>
6.1 HTML5的框架
查看>>
Nginx的500,502,504错误解决方法
查看>>
SAP MM MM17里不能修改物料主数据'Purchasing Value Key'字段值?
查看>>
python 基础语法知识(一)
查看>>
ssh整合
查看>>
大数组分时加载算法 timedChunk
查看>>
leetcode -- 11. 盛最多水的容器
查看>>
vim vimtutor
查看>>
Jmeter学习笔记12-监听器以及测试结果的分析
查看>>
ASP.NET Core中使用GraphQL - 第九章 在GraphQL中处理多对多关系
查看>>
Python 开发与测试 Webservice(SOAP)
查看>>
结对第一次—原型设计(文献摘要热词统计)
查看>>
selenium +python 对table的操作
查看>>