文档章节

log4J日志配置

iborder
 iborder
发布于 2016/12/12 23:42
字数 796
阅读 28
收藏 0

Apache的开源项目log4j是一个功能强大的日志组件,提供方便的日志记录。

使用log4j需要导入log4j-core-xx.jar和log4j-api-xx.jar

log4j1.x版本只需要导入一个jar包,通过一个*.properties 或 *.xml的文件作为主配置文件;

log4j2.x版本都要导入两个jar包,采用*.xml,*.json或者*.jsn文件作为配置文件;

在默认情况下,系统选择配置文件的优先级如下:

  1.  log4j-test.json 或 log4j-test.jsn文件
  2.  log4j2-test.xml
  3.  log4j.json 或 log4j.jsn文件
  4.  log4j2.xml

log4j1.x和log4j2.x两个版本使用有一些区别,下面主要讲解使用log4j2.x

Log4j最新版本是apache-log4j-2.7

Log4j由三个重要的组件构成:

日志级别(Logger):从高到低有FATAL、ERROR、WARN、 INFO、DEBUG、TRACE,分别用来指定这条日志信息的重要程度;

日志信息输出目的地(Appender):日志输出目的地可以是控制台、文件和网络设备等;

日志信息输出格式(Layout):控制了日志信息的显示内容。

1、配置文件

Log4j有默认的配置,日志级别是ERROR,输出到控制台

log4j2.xml(放在src目录下,运行时自动加载)

<?xml version="1.0" encoding="UTF-8"?>
<!-- Configuration节点的属性status,用于设置log4j自身内部运行日志输出(只输出到控制台),可以不设置,当设置成trace时,你会看到log4j2内部各种详细输出 -->
<configuration status="OFF">
    <!--定义所有的appender-->
    <appenders>
        <!--配置输出控制台-->
        <Console name="Console" target="SYSTEM_OUT">
            <!--控制台只输出level及以上级别的信息(onMatch),其他的直接拒绝(onMismatch)-->
            <ThresholdFilter level="trace" onMatch="ACCEPT" onMismatch="DENY"/>
            <!--这个都知道是输出日志的格式-->
            <PatternLayout pattern="%d{HH:mm:ss.SSS} %-5level %class{36} %L %M - %msg%xEx%n"/>
        </Console>
        <!--打印出日志到文件,append属性设置为false,每次运行程序会自动先清空之前的日志-->
        <File name="error" fileName="log/error.log" append="false">
        	<ThresholdFilter level="error" onMatch="ACCEPT" onMismatch="DENY"/>
            <PatternLayout pattern="%d{HH:mm:ss.SSS} %-5level %class{36} %L %M - %msg%xEx%n"/>
        </File>

        <!--打印出日志到文件,单个日文件大小超过size指定的值,则该日志会自动存入按年份-月份建立的文件夹下面并进行压缩,作为存档-->
        <RollingFile name="RollingFile" fileName="log/app.log" filePattern="log/$${date:yyyy-MM}/app-%d{MM-dd-yyyy}-%i.log.gz">
            <PatternLayout pattern="%d{yyyy-MM-dd 'at' HH:mm:ss z} %-5level %class{36} %L %M - %msg%xEx%n"/>
            <SizeBasedTriggeringPolicy size="50MB"/>
            <!-- DefaultRolloverStrategy属性如不设置,则默认为最多同一文件夹下7个文件,这里设置了20. -->
            <DefaultRolloverStrategy max="20"/>
        </RollingFile>
    </appenders>
    <!--定义所有logger,appender引入到logger才会生效-->
    <loggers>
    <!-- 每个logger都有一个日志级别,用来控制日志的输出。未分配级别的logger将自动继承它最近的父logger的日志级别 -->
    	<!--
        	additivityz值为true,如果logger也满足root的条件,会出现打印两遍的情况。
        -->
        <logger name="cn.iborder.test.TestLog4j" level="trace" additivity="false">
            <appender-ref ref="Console"/>
            <appender-ref ref="error"/>
        </logger>
        <!--默认root的logger-->
        <root level="trace">
            <appender-ref ref="Console"/>
        </root>
    </loggers>
</configuration>

2、测试实例

package cn.iborder.test.page;

import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import org.junit.Test;

public class TestLog4j {
	//通过指定的名字获得logger
	private static Logger logger = LogManager.getLogger(TestLog4j.class.getName());
	
	@Test
	public void test1() {
		logger.trace("trace级别");
		logger.debug("debug级别");
		logger.info("info级别");
		logger.warn("warn级别");
		logger.error("error级别");
		logger.fatal("fatal级别");
	}
}

 

© 著作权归作者所有

共有 人打赏支持
iborder
粉丝 4
博文 73
码字总数 48998
作品 0
揭阳
程序员
Java --log4j.properties详解

已经完结的工程中用到了log4j,抽时间写一篇日志记录下。 //参考文章如下 http://it.oyksoft.com/log4j/ 一、log4j是什么?有什么用? Log4j是一个日志记录工具,基于java语言的。我们可以将...

求是科技
2015/11/03
0
0
java 日志框架——log4j

Log4J是JAVA下的一款日志组件 下载: http://logging.apache.org/log4j/2.x/download.html 下面的示例我使用最新版本2.7无法正常运行,最新版本使用方法可能不同。本文示例使用log4j-1.2.15测...

xundh
05/09
0
0
Maven及LOG4J配置示例

刚才在测试小项目里配置了一下log4j,很久不用,有些遗忘了,配置完发出来备忘一下 首先用maven引入log4j,相关的代码如下: <dependency><groupId>log4j</groupId><artifactId>log4j</artif......

王小明123
2012/12/25
0
2
log4j及log4j2在Spring MVC中的使用.md

项目已上线许久,项目中使用的是log4j 1.x版本,本来日志也可以正常记录,但是运维报怨说,你们的日志太大了,catalina.out日志输出无限大,以致有些应用出现服务器存储告警,所以建议我们:...

混迹在Amoy
07/28
0
0
jboss log4j冲突分析与解决

Log4j作为日志组件被大多数的系统所使用,Jboss也不例外的采用了Log4j作为它的日志输出组件。 但在使用JBoss时,很多人经常碰到一些冲突,这些冲如自己配置的log4j文件无效,系统抛org.jboss...

职通网
2012/07/16
0
0

没有更多内容

加载失败,请刷新页面

加载更多

linux 系统的运行级别

运行级别 运行级别 | 含义 0 关机 1 单用户模式,可以想象为windows 的安全模式,主要用于修复系统 2 不完全的命令模式,不含NFS服务 3 完全的命令行模式,就是标准的字符界面 4 系统保留 5 ...

Linux学习笔记
今天
2
0
学习设计模式——命令模式

任何模式的出现,都是为了解决一些特定的场景的耦合问题,以达到对修改封闭,对扩展开放的效果。命令模式也不例外: 命令模式是为了解决命令的请求者和命令的实现者之间的耦合关系。 解决了这...

江左煤郎
今天
3
0
字典树收集(非线程安全,后续做线程安全改进)

将500W个单词放进一个数据结构进行存储,然后进行快速比对,判断一个单词是不是这个500W单词之中的;来了一个单词前缀,给出500w个单词中有多少个单词是该前缀. 1、这个需求首先需要设计好数据结...

算法之名
昨天
15
0
GRASP设计模式

此文参考了这篇博客,建议读者阅读原文。 面向对象(Object-Oriented,OO)是当下软件开发的主流方法。在OO分析与设计中,我们首先从问题领域中抽象出领域模型,在领域模型中以适当的粒度归纳...

克虏伯
昨天
1
0
Coding and Paper Letter(四十)

资源整理。 1 Coding: 1.Tomislav Hengl撰写的非官方作者指南:Michael Gould•Wouter Gerritsma。 UnofficialGuide4Authors 2.R语言包rwrfhydro,社区贡献的工具箱,用于管理,分析和可视化...

胖胖雕
昨天
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部