1、 Log4j是什么?
Log4j简单来说就是用来记日志的,帮助程序猿调试和分析,他的作用是很大的,只是我们还没有加以利用,这里做一个简介,要了解详细信息请访问log4j官网。
2、Log4j的概念
Log4j中有三个主要的组件,它们分别是 Logger、Appender和Layout。
- Log4j 允许开发人员定义多个Logger,每个Logger拥有自己的名字,Logger之间通过名字来表明隶属关系。有一个Logger称为Root,它永远 存在,且不能通过名字检索或引用,可以通过Logger.getRootLogger()方法获得,其它Logger通过 Logger.getLogger(String name)方法。
- Appender则是用来指明将所有的log信息存放到什么地方,Log4j中支持多种appender,如 console、files、GUI components、NT Event Loggers等,一个Logger可以拥有多个Appender,也就是你既可以将Log信息输出到屏幕,同时存储到一个文件中。
- Layout的作用是控制Log信息的输出方式,也就是格式化输出的信息。
3、Log4j的配置文件
虽然可以不用配置文件,而在程序中实现配置,但这种方法在如今的系统开发中显然是不可取的,能采用配置文件的地方一定一定要用配置文件。 Log4j支持两种格式的配置文件:XML格式和Java的property格式,如下:
log4j.rootLogger=debug,CONSOLE log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout log4j.appender.CONSOLE.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n log4j.appender.DEFAULT=org.apache.log4j.DailyRollingFileAppender log4j.appender.DEFAULT.DatePattern='.'yyyy-MM-dd log4j.appender.DEFAULT.Append=true log4j.appender.DEFAULT.File=${user.home}/logs/zsht-default.log log4j.appender.DEFAULT.layout=org.apache.log4j.PatternLayout log4j.appender.DEFAULT.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n log4j.appender.REST=org.apache.log4j.DailyRollingFileAppender log4j.appender.REST.DatePattern='.'yyyy-MM-dd log4j.appender.REST.Append=true log4j.appender.REST.File=${user.home}/logs/zsht-rest.log log4j.appender.REST.layout=org.apache.log4j.PatternLayout log4j.appender.REST.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n # Sense log4j.appender.SENSE=org.apache.log4j.DailyRollingFileAppender log4j.appender.SENSE.DatePattern='.'yyyy-MM-dd log4j.appender.SENSE.Append=true log4j.appender.SENSE.File=${user.home}/logs/sense.log log4j.appender.SENSE.layout=org.apache.log4j.PatternLayout log4j.appender.SENSE.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n # CACHE log4j.appender.CACHE=org.apache.log4j.DailyRollingFileAppender log4j.appender.CACHE.DatePattern='.'yyyy-MM-dd log4j.appender.CACHE.Append=true log4j.appender.CACHE.File=${user.home}/logs/cache.log log4j.appender.CACHE.layout=org.apache.log4j.PatternLayout log4j.appender.CACHE.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n # SESSION log4j.appender.SESSION=org.apache.log4j.DailyRollingFileAppender log4j.appender.SESSION.DatePattern='.'yyyy-MM-dd log4j.appender.SESSION.Append=true log4j.appender.SESSION.File=${user.home}/logs/session.log log4j.appender.SESSION.layout=org.apache.log4j.PatternLayout log4j.appender.SESSION.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n log4j.logger.REST=INFO,REST log4j.logger.org.jpxx.sense=INFO,SENSE log4j.logger.org.jpxx.commons.cache=INFO,CACHE log4j.logger.org.jpxx.commons.session=INFO,SESSION
设置root
格式为log4j.rootLogger=[level],appenderName, ...,其中level就是设置需要输出信息的级别(info,debug等),后面是appender,相当于指定日志信息输出到哪个地方,可以同时指 定多个目的地,如上述配置中的CONSOLE,DEFAULT都是。
设置appender
Appender配置日志的输出目的地
log4j.appender.DEFAULT=org.apache.log4j.DailyRollingFileAppender log4j.appender.DEFAULT.DatePattern='.'yyyy-MM-dd
第二天原文件的文件名改为xx.yyyy-MM-dd
Log4j提供的appender有以下几种:
org.apache.log4j.ConsoleAppender(控制台) org.apache.log4j.FileAppender(文件) org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件) org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生新文件) org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方) org.apache.log4j.jdbc.JDBCAppender(将日志信息存入数据库)
配置文件路径
log4j.appender.DEFAULT.File=${user.home}/logs/zsht-default.log log4j.appender.DEFAULT.Append=true
Append=true表示不覆盖原文件,从末尾追加日志
${user.home}表示当前用户
配置日志信息的格式(布局)
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
Log4j提供的常用layout有以下几种:
org.apache.log4j.HTMLLayout(以HTML表格形式布局) org.apache.log4j.PatternLayout(可以灵活地指定布局模式) org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串) org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)
使用PatternLayout布局比较灵活,可以使用配置
log4j.appender.CONSOLE.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} [%c]-[%p] %m%n
来定义具体的输出形式,Log4J采用类似C语言中的printf函数的打印格式格式化日志信息
Log4j中常用的打印参数
%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS} %c 输出所属的类目,通常就是所在类的全名 %p 输出优先级,即DEBUG,INFO %m 输出代码中指定的消息 %n 输出一个回车换行符,Windows平台为“\r\n”,Unix平台为“\n” %r 输出自应用启动到输出该log信息耗费的毫秒数 %t 输出产生该日志事件的线程名 %l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。
配置子日志属性项(可以不配置)
REST的日志同时会输出到rootLogger和REST
log4j.logger.REST=INFO,REST
不输出org.jpxx.sense的日志
log4j.logger.org.jpxx.sense=INFO,SENSE log4j.additivity.org.jpxx.sense=false
4.项目须知(重要)
- log4j.properties文件的位置:在eclipse中位于web项目的src/log4j.properties,在生产服务器上位于 tomcat目录/webapps/ROOT/WEB-INF/classes/log4j.properties
- 日志文件的位置(.log文件):通过log4j.appender.appenderName.File这个属性配置,appenderName是自己命名的,${user.home}表示当前用户,不知道的可以通过代码
System.getProperty("user.home");
获得数据 - 如果部署环境是windows系统,日志不能输出在c盘,除非系统只有一个盘符c盘。日志文件会不断积累,如果没有监控,当日志文件占满整个c盘,系统将会崩溃
- 生产发布的应用日志的等级为info,不能为debug,debug主要用于程序猿调试使用,如果生产使用debug等级,日志量会翻倍,更容易占满空间
相关推荐
log4j的使用习惯,让每个类都拥有一个private static的Logger对象,用来输出该类中的全部日志信息 ,使用xml文件来完成对log4j环境的配置。在项目的main class中的静态初始化块里放log4j环境的配置代码。注意:在一...
根据log4j(jakarta-log4j-1.2.8)的开发包自带文档的manual翻译
针对Log4j 2 远程代码执行漏洞,需要用到的升级资源包,适用于maven资源库,包括log4j,log4j-core,log4j-api,log4j-1.2-api,log4j-jpa等全套2.15.0 maven资源库jar包。如果是maven本地仓库使用,需要将zip包解压...
描述Log4j2的配置详情及相对Log4j的优点,包括效率测试程序
apache-log4j-1.2.15.jar, apache-log4j-extras-1.0.jar, apache-log4j-extras-1.1.jar, apache-log4j.jar, log4j-1.2-api-2.0.2-javadoc.jar, log4j-1.2-api-2.0.2-sources.jar, log4j-1.2-api-2.0.2.jar, log4j-...
若依框架使用的log4j2.16.0,修复log4j漏洞log4j2下载最新log4j2.16.0下载
Apache log4j2零日漏洞,根据 log4j-2.15.0-rc2 版本编译生成log4j-api-2.15.0.jar 1.解压你的jar jar xvf XXX.jar 2. 删除旧版本jar cd ./BOOT-INF/lib rm -rf log4j-api-*.jar 3. 上传新版本log4j-api-2.15.0....
Log4j 是一个日志记录框架,Log4j 2 是对 Log4j 的升级,提供了重大改进,超越其前身 Log4j 1.x,并提供许多其它现代功能 ,例如对标记的支持、使用查找的属性替换、lambda 表达式与日志记录时无垃圾等。 Apache ...
Apache log4j2零日漏洞,根据 log4j-2.15.0-rc2 版本编译生成log4j-api-2.15.0.jar 1.解压你的jar jar xvf XXX.jar 2. 删除旧版本jar cd ./BOOT-INF/lib rm -rf log4j-api-*.jar 3. 上传新版本log4j-api-...
1. Log4j 简介 ........... 2. 下载与使用............ 2.1 下载 log4j 的 jar 文件 2.2 编写一个测试类 ...... 2.3 编写配置文件........ 2.4 输出结果 ........... 3. Log4j 构成 ........... 4. Log4j 使用方法.....
log4j.rootLogger=debug,CONSOLE,testfile,A1,MAIL ################### # Console Appender ################### log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender log4j.appender.CONSOLE.Target=...
下面小编就为大家带来老生常谈Log4j和Log4j2的区别(推荐)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
log4j+slf4j实现 log4j测试代码,log4j+slf4j实现 log4j测试代码,
apache下载太慢,特搬到国内下载。修复log4j漏洞log4j2下载最新log4j2.16.0下载
log4j-API-最新稳定版本log4j-1.2.17 apache log4j-API-最新稳定版本log4j-1.2.17
log4j-api-2.12.4.jar和log4j-core-2.12.4.jar,该版本避免log4j漏洞问题。
Log4j2学习笔记,引入log4j2的依赖-log4j2.xml配置模板-application.properties文件配置-使用
Log4j比较全面的配置 log4j.rootLogger=DEBUG,CONSOLE,A1,im log4j.addivity.org.apache=true # 应用于控制台 log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender log4j.appender.Threshold=DEBUG log4j....
赠送jar包:log4j-api-2.12.1.jar; 赠送原API文档:log4j-api-2.12.1-javadoc.jar; 赠送源代码:log4j-api-2.12.1-sources.jar; 赠送Maven依赖信息文件:log4j-api-2.12.1.pom; 包含翻译后的API文档:log4j-api-...
赠送jar包:log4j-slf4j-impl-2.12.1.jar; 赠送原API文档:log4j-slf4j-impl-2.12.1-javadoc.jar; 赠送源代码:log4j-slf4j-impl-2.12.1-sources.jar; 赠送Maven依赖信息文件:log4j-slf4j-impl-2.12.1.pom; ...