官网:https://logging.apache.org/log4j/2.x/

使用 Log4j 的步骤:

第一步 引入 Log4j 的 jar 包

1. 直接下载 log4j-x.x.x.jar 到 classpath 中

2. 使用 maven 配置,在 pom.xml 中增加如下依赖即可

<denpendency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>

第二步 配置 Log4j

1. Log4j 可以通过 java 程序动态设置,但每次修改后需要重新编译

2. 通过配置文件的方式进行配置

-- xml 文件

-- properties 文件(推荐使用)Java 特性文件(键=值)

第三步 在需要输出日志的类中加入相关语句

一个 log4j.properties 的例子

### 全局配置 ###
log4j.rootCategory=INFO, stdout
log4j.rootLogger=info, stdout ### 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{ABSOLUTE} %5p - %m%n ### set package ###
log4j.logger.org.springframework=info
log4j.logger.org.apache.catalina=info
log4j.logger.org.apache.commons.digester.Digester=info
log4j.logger.org.apache.catalina.startup.TldConfig=info
log4j.logger.chb.test=debug

Log4j 由三个重要的组件构成:日志信息的优先级、日志信息的输出目的地、日志信息的输出格式。

日志信息的优先级从高到低有:ERROR、WARN、INFO、DEBUG 等,分别用来指定这条日志信息的重要程度

日志信息的输出目的地指定了日志将打印到控制台还是文件中

日志嘻嘻的输出格式指定了日志信息的显示内容

日志信息的优先级

org.apache.logging.log4j.Level 类中指定了以下 8 个日志级别

OFF  // most specific, no logging. No events will be logged.
FATAL // most specific, little data. A severe error that will prevent the application from continuing.
ERROR // An error in the application, possibly recoverable.
WARN // An event that might possible lead to a error.
INFO // An event for informational purpose.
DEBUG // A general debugging event
TRACE // least specific, a lot of data. A fine-grained debug message, typically capturing the flow through the applicaiton.
ALL // least specific, all data. All events should be logged.

如果使用了级别 P,则所有级别低于 P 的日志信息都不会被打印出来

最高级别 OFF > FATAL > ERROR > WARN > INFO > DEBUG > TRACE > ALL 最低级别

例如 如果启用 WARN 级别,则 ERROR、FATAL、OFF级别都会开启

配置根 Logger

全局 Logger 主要定义 log4j 支持的日志级别及日式输出目的地,其语法为

log4j.rootLogger = [LEVEL], appenderName, appenderName, ...

LEVEL 是日志记录的级别

appenderName 指定日志信息输出的位置,可以同时指定多个输出的目的地。

配置日志信息输出目的地 Appender,其语法如下

log4j.appender.appenderName = fully.qualified.name.of.appender.class
log4jappender.appenderName.option1 = value1
...
log4j.appender.appenderName.optionN = valueN

Log4j 提供的 appender 有以下几种:

org.apache.log4j.ConsoleAppender  // 控制台
org.apache.log4j.FileAppender // 文件
org.apache.log4j.DailyRollingFileAppender // 每天产生一个日志文件
org.apache.log4j.RollingFileAppender // 文件大小到达指定尺寸的时候产生一个新的文件
org.apache.log4j.WriterAppender // 将日志信息以格式流发送到任意指定的地方

配置日志信息的格式(布局),其语法为:

log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class
log4j.appender.appenderName.layout.option1 = value1
..
log4j.appender.appenderName.layout.optionN = valueN

Log4j 提供的 layout 有以下几种:

org.apache.log4j.HTMLLayout  // 以 HTML 表格的形式布局
org.apache.log4j.PatternLayout // 可以灵活的指定布局模式
org.apache.log4j.SimpleLayout // 包含日志信息的级别和信息字符串
org.apache.log4j.TTCCLayout // 包含日志产生的时间、线程、类别等信息

Log4j 采用类似于 C 语言中的 printf 函数的打印格式来格式化日志信息,打印参数如下:

%m  // 输出代码中指定的消息
%p // 输出优先级,即 DEBUG、INFO、WARN、ERROR、FATAL
%r // 输出自应用启动到输出到该 log 信息耗费的毫秒数
%c // 输出所属的类,通常就是所在类的全限定名
%t // 输出产生该日志事件的线程名
%n // 输出一个回车换行符,Windows 平台为 “rn” Unix 平台为 “n”
%d // 输出日志时间点的日期或时间,默认格式为 ISO8601,也可以在其后指定格式,比如:%d{yyyy MM dd HH:mm:ss, SSS}
%l // 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数,举例:Testlog4.main(TestLog4.java:10)

控制台选项

Threshold=DEBUG  // 指定日志消息的输出最低层次
ImmediateFlush=true // 默认值是 true,意味着所有的消息都会被立即输出
Target=System.err // 默认情况下,System.out 指定输出控制台

FileAppender 选项

Threshold=DEBUF  // 指定日志消息的输出最低层次。
ImmediateFlush=true // 默认值是true,意谓着所有的消息都会被立即输出。
File=mylog.txt // 指定消息输出到mylog.txt文件。
Append=false // 默认值是true,即将消息增加到指定文件中,false指将消息覆盖指定的文件内容。

RollingFilerAppender 选项

Threshold=DEBUG  // 指定日志消息的输出最低层次。
ImmediateFlush=true // 默认值是true,意谓着所有的消息都会被立即输出。
File=mylog.txt // 指定消息输出到mylog.txt文件。
Append=false // 默认值是true,即将消息增加到指定文件中,false指将消息覆盖指定的文件内容。
MaxFileSize=100KB // 后缀可以是KB, MB 或者是 GB. 在日志文件到达该大小时,将会自动滚动,即将原来的内容移到mylog.log.1文件。
MaxBackupIndex=2 // 指定可以产生的滚动文件的最大数。

Log4j 日志组件的更多相关文章

  1. Log4J日志组件

    Log4j,  log for java, 开源的日志组件! 使用步骤: 1. 下载组件,引入jar文件; log4j-1.2.11.jar 2. 配置 :  src/log4j.properties ...

  2. java日志组件介绍(common-logging,log4j,slf4j,logback )

    转自:http://www.blogjava.net/daiyongzhi/archive/2014/04/13/412364.html common-logging是apache提供的一个通用的日志 ...

  3. java中的日志组件-log4j

    1.为什么使用日志组件 Log4J是Apache的一个开放源代码项目,它是一个日志操作包,通过使用Log4J,可以指定日志信息输出的目的地,如控制台.文件.CUI组件.NT的事件记录器:还可以控制每一 ...

  4. 转:java日志组件介绍(common-logging,log4j,slf4j,logback )

    原网址:http://www.blogjava.net/daiyongzhi/archive/2014/04/13/412364.html common-logging common-logging是 ...

  5. 【转】java日志组件介绍(common-logging,log4j,slf4j,logback )

    common-logging common-logging是apache提供的一个通用的日志接口.用户可以自由选择第三方的日志组件作为具体实现,像log4j,或者jdk自带的logging, comm ...

  6. Java日志组件2---Log4j(org.apache.log4j.Logger)

    如果我们在项目中,需要记录的东西并不多,而且也不需要有太多区分,使用jdk的自带Log完全可以解决问题.但是,在开发的过程中,大多数项目都比较大,为方便找到程序的bug,都是需要系统的记录日志的.这里 ...

  7. 关于log4j、jul、jcl、slf4j等等日志组件的理解

    日志组件: 我们经常在开发项目的时候,需要打印记录项目过程中的一些日志.那我们经常大概会用到 log4j.jul.jcl.slf4j.simple.nop.logback 等等,那我们就详细介绍下这些 ...

  8. 你的日志组件记录够清晰嘛?--自己开发日志组件 Logger

    现在现成的日志组件实在是太多太多,为什么我还需要自己实现呢????? 需求来源于java的log4j, [07-31 16:40:00:557:WARN : com.game.engine.threa ...

  9. Log4J日志配置详解

    一.Log4j简介 Log4j有三个主要的组件:Loggers(记录器),Appenders (输出源)和Layouts(布局).这里可简单理解为日志类别,日志要输出的地方和日志以何种形式输出.综合使 ...

随机推荐

  1. react 在 componentWillMount() 中调用异步函数时,componentWillMount() finishes after render()

    刚开始使用 react,很多属性.方法不是很熟.在此记录下我所遇到的问题及解决方法. 我在 componentWillMount() 中调用了一个异步函数,在返回结果中调用 this.setState ...

  2. Bootstrap 插件收集

    Bootstrap-Mutilselect  将下拉选项扩展支持多选以及多种选择方式 http://davidstutz.de/bootstrap-multiselect/ Bootstrap Sel ...

  3. springboot整合mybatis之注解方式

    1. 创建maven项目,工程目录如下图 2. 在pom.xml文件中添加mybatis依赖. 3. 创建实体类,并生成construct方法,getter和setter方法.同时在数据库中创建对应的 ...

  4. c# 泛型和IComparable<T>接口

    泛型 因为我们在编程中想先不定义数据类型,只想先写逻辑,就可以使用Object类型, 这样我们的逻辑就适用于所有类型,但是,在运行中,Object类型的变量会需要 转换到对应类型,浪费资源,所有出现泛 ...

  5. gitea 源码阅读笔记 002 生成无依赖单文件可执行包

    gitea bindata static gitea 可以通过 make generate 生成一个单文件可执行程序, 该文件不需要任何其它依赖,直接可以单独执行. 对于用户的安装.升级和生成dock ...

  6. CodeSmith和Powerdesigner的搭建和实例化操作 转载自黄聪同学

    好了,废话少说,开始我们的CodeSmith旅程吧,我先讲讲这个系列教程要完成的目标吧,众所周知,CodeSmith其中一个强大的功能就是依照模板生成批量代码,这也是吸引着众多编程人士使用它的原因,它 ...

  7. shell脚本(一)

     shell脚本(一) 定义:脚本就是一条条命令的堆积.常见脚本有:js asp,jsp,php,python Shell特点:简单易用高效 Shell分类:图形界面(gui shell) 命令行界面 ...

  8. ScrollView滑动到底部或顶部监听,ScrollView滑动到底部或顶部再继续滑动监听;

    ScrollView滑动到底部或顶部后,再继续滑动达到一定距离的监听: ScrollView滑动到底部或顶部的监听: /** * 监听ScrollView滚动到顶部或者底部做相关事件拦截 */ pub ...

  9. mysql修改用户密码的方法及命令

    方法1: 用SET PASSWORD命令 首先登录MySQL. 格式:mysql> set password for 用户名@localhost = password('新密码'); 例子:my ...

  10. 作着玩:登录页(纯css,不支持ie9以下)

    支持chrome FireFox 和 IE10+,(IE9也能显示,IE9以下不支持) <style type="text/css"> body{position:re ...