`
Josh_Persistence
  • 浏览: 1651458 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类

Log4j.xml和Log4j2.xml的简单认识 - log4j2/log4j的区别

阅读更多

问题描述:

 

有时在项目中导入log4j的jar包,并配置log4j.xml或者是log4j2.xml后,在代码中引入log4j的API,并不能成功的将log写入控制台或者文件中。

 

原因有很多很多种,下面将介绍经过我测试log写入成功的事例。

 

在开始前,需要谨记log4j的几种级别:trace<debug<info<warn<error<fatal, 级别之间是包含的关系,意思是如果你设置日志级别是trace,则大于等于这个级别的日志都会输出。

 

 

成功例子1 log4j.xml:

1. 导入log4j2的jar包,主需要导入log4j2的core包即可。如:log4j-core.2.1.jar,引入改jar包会自动引入

log4j-api.2.1.jar.

 

<dependency>
      <groupId>org.apache.logging.log4j</groupId>
      <artifactId>log4j-core</artifactId>
      <version>2.1</version>
</dependency>

 

 

2.在classpath中配置log4j.xml,注意不是log4j2.xml,其内容如下

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration SYSTEM "http://logging.apache.org/log4j/1.2/apidocs/org/apache/log4j/xml/doc-files/log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/" debug="false">

<!-- Set INFO to WARN for warning-level logging, or DEBUG for debug-level logging. -->

	<!-- Output to terminal by default. -->
	<appender name="terminal" class="org.apache.log4j.ConsoleAppender">
		<param name="Threshold" value="INFO" />
		<param name="Target" value="System.out" />
		<layout class="org.apache.log4j.PatternLayout">
<!-- param name="ConversionPattern" value="%d{ABSOLUTE} [%t] %-5p [%c{1}] %m%n"/ -->
		<param name="ConversionPattern" value="%-d [%t] %-5p %c:%L - %m%n" />
		</layout>
	</appender>

	<!-- Optional: asynchronous file output (set <appender-ref ref="asynch-file"/> in root below). -->
	<appender name="asynch-file" class="org.apache.log4j.AsyncAppender">
		<param name="locationInfo" value="false" />
		<appender-ref ref="out-file" />
	</appender>

	<!-- Optional: asynchronous file location (set <appender-ref ref="asynch-file"/> in root below). -->
	<appender name="out-file" class="org.apache.log4j.RollingFileAppender">
		<param name="Threshold" value="INFO" />
		<!-- <param name="file" value="${app.logfile}"/> -->
		<param name="file" value="log/automation.log" />
		<param name="MaxFileSize" value="50MB" />
		<param name="MaxBackupIndex" value="50" />
		<layout class="org.apache.log4j.PatternLayout">
       <param name="ConversionPattern" value="%-d [%t] %-5p %c %X{processID}-%X{queryIndex} -  %m  %n" />
		</layout>
	</appender>

	<logger name="com.wsheng.uiautomation.test">
		<level value="INFO" />
	</logger>

	<logger name="com.wsheng.uiautomation.sitestatus">
		<level value="INFO" />
	</logger>

	<root>
		<level value="INFO" />
		<appender-ref ref="terminal" />
		<appender-ref ref="out-file" />
	</root>
</log4j:configuration>

 

3. 在项目中写log的代码:

import org.apache.log4j.Logger;

protected static Logger logger = Logger.getLogger(BaseTestPlan.class);

 需要注意的是此处导入的是org.apache.log4j.Logger;如果使用下面的代码,则不能写入log

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

protected static Logger logger = LogManager.getLogger(BaseTestPlan.class);

即便是将上面的log4j.xml改为log4j2.xml也不能写入log。

 

这是因为log4j2.xml和log4j.xml在配置上有区别。

 

成功例子2: log4j2.xml

 

1. 和log4j.xml一样,也导入log4j2的jar包,主需要导入log4j2的core包即可。如:log4j-core.2.1.jar,引入改jar包会自动引入log4j-api.2.1.jar.

 

 <dependency>
     <groupId>org.apache.logging.log4j</groupId>
     <artifactId>log4j-core</artifactId>
     <version>2.1</version>
</dependency>

 

2.在classpath中配置log4j2.xml,注意不是log4j.xml,其内容如下

<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="WARN">

	<properties>
		<property name="logPath">log</property>
	</properties>
	
	<Appenders>
		<Console name="Console" target="SYSTEM_OUT">
			<PatternLayout pattern="%d{YYYY-MM-dd HH:mm:ss} [%t] %-5p %c{1}:%L - %msg%n" />
			<!-- <PatternLayout pattern="%d{HH:mm:ss} [%t] %-5level %logger{36} - %msg%n" /> -->
			<!-- <PatternLayout pattern="%-d [%t] %-5p %c{1}:%L - %m%n" /> -->
		</Console>
		
	<!-- <File name="LogFile" filename="${sys:catalina.home}/logs/automation.log">
	<PatternLayout pattern="%d{YYYY-MM-dd HH:mm:ss} [%t] %-5p %c{1}:%L - %msg%n" />
		</File> -->
		
		<RollingFile name="RollingFile" filename="${logPath}/automation.log"
			filepattern="${logPath}/%d{YYYYMMddHHmmss}-automation.log">
	<PatternLayout pattern="%d{YYYY-MM-dd HH:mm:ss} [%t] %-5p %c{1}:%L - %msg%n" />
			<Policies>
				<SizeBasedTriggeringPolicy size="100 MB"/>
			</Policies>	
			 <DefaultRolloverStrategy max="20"/>
		</RollingFile>
		
	</Appenders>
	<Loggers>
		<Root level="info">
			<AppenderRef ref="Console" />
			<!-- <AppenderRef ref="LogFile" /> -->
			<AppenderRef ref="RollingFile" />
		</Root>
	</Loggers>
</Configuration>

 

3. 在项目中写log的代码:

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

protected static Logger logger = LogManager.getLogger(BaseTestPlan.class);

 如果使用 org.apache.log4j.Logger,得到的结果是能写入控制台,但不能写入对应的文件。

import org.apache.log4j.Logger;

protected static Logger logger = Logger.getLogger(BaseTestPlan.class);

 

 Note: 如果启动的时候报类似下面的异常:

2015-04-30 15:10:07,962 WARN Could not instantiate SimpleDateFormat with pattern YYYYMMddHHmmss java.lang.IllegalArgumentException: Illegal pattern character 'Y'

可将YYYY改成小写的yyyy试一试。

 

1
0
分享到:
评论

相关推荐

    log4j.jar各个版本

    apache-log4j-1.2.15.jar, apache-log4j-extras-1.0.jar, apache-log4j-extras-1.1....log4j-xml-1.3alpha-7.jar, log4j.jar, org.apache.log4j_1.2.15.v201005080500.jar, org.apache.log4j_1.2.15.v201012070815.jar

    log4j.jar及log4j.xml

    以上内容详细介绍了Log4j.jar的核心组件和log4j.xml配置文件的作用,它们共同构成了Log4j日志框架的基础。通过合理的配置和使用,Log4j能够为开发者提供强大且灵活的日志管理能力,帮助他们更好地监控和维护Java应用...

    log4j-api-2.17.1.jar和log4j-core-2.17.1.jar

    本文将详细探讨Log4j2中的两个关键组件:log4j-api-2.17.1.jar和log4j-core-2.17.1.jar。 首先,log4j-api-2.17.1.jar是Log4j2的核心API库,它定义了日志记录的接口和抽象类,为应用程序提供了一套编程模型。这些...

    log4j与web.xml的配置

    2. **Log4j配置文件(log4j.properties或log4j.xml)** - 在Java项目中,通常会有一个log4j配置文件,用于定义日志记录的级别、输出方式和格式。 - 示例配置: ``` log4j.rootLogger=DEBUG, FILE log4j....

    log4j.xml(MyBatis框架)

    这里是log4j.xml详细的配置,在使用MyBatis框架时必要的一种配置。

    Log4j2学习log4j2.xml配置模板

    下面我们将学习 Log4j2 配置模板的使用和配置。 引入 Log4j2 依赖 在使用 Log4j2 之前,需要在 Maven 项目中引入 Log4j2 的依赖。我们可以在 pom.xml 文件中添加以下依赖项: ```xml &lt;groupId&gt;org.spring...

    项目配置文件( spring-mvc.xml spring-mybatis.xml web.xml log4j.properties)

    这里提到的四个关键配置文件——`spring-mvc.xml`、`spring-mybatis.xml`、`web.xml`以及`log4j.properties`,对于一个基于Java的Web应用来说至关重要,特别是使用Spring MVC和MyBatis框架的时候。接下来,我们将...

    log4j的详细配置,log4j.xml和log4j.properties,日志输出到文件,邮件,数据库,控制台等

    Log4j提供了多种配置方式,其中最常用的有两种:XML格式的`log4j.xml`和properties格式的`log4j.properties`。接下来,我们将深入探讨如何通过这两种配置文件来设置日志输出的目标、级别以及格式。 1. **XML配置** ...

    log4j.xml

    首先,log4j.xml是一个基于XML格式的配置文件,它是Log4j框架的核心组成部分,用于定义日志记录的行为和输出方式。与传统的log4j.properties文件相比,XML格式更易于阅读和维护,同时提供了更好的扩展性。 配置文件...

    Log4J.xml的模板

    标题中的“Log4J.xml”指的是Apache Log4j框架的配置文件。Log4j是Java平台上广泛使用的日志记录工具,它允许程序员以灵活和可配置的方式控制应用程序的日志输出。XML格式的配置文件提供了更高级别的结构和可读性,...

    log4j-api-2.12.4.ja和log4j-core-2.12.4.jar

    配置Log4j通常通过一个XML或JSON格式的配置文件完成,例如`log4j2.xml`或`log4j2.json`,这个文件定义了日志的输出级别、目的地(如控制台、文件、数据库等)以及格式。 总的来说,Log4j 2是Java开发中不可或缺的...

    log4j2.xml记录日志到到数据库

    总结,Log4j2通过XML配置文件实现了与MySQL数据库的集成,允许开发者将日志信息存储在数据库中,便于长期保存和分析。理解Log4j2的配置和使用是每个Java开发者必备的技能,这对于日后的故障排查和系统维护至关重要。...

    log4j.jar和commons-logging.jar

    配置日志文件时,你需要在项目中包含这两个JAR文件,并创建一个log4j的配置文件(通常是log4j.properties或log4j.xml)。配置文件中,你可以指定日志级别、输出目的地、日志格式等。例如,以下是一个简单的`log4j....

    新版本与旧版本log4j.jar包下载,附使用说明----.zip

    2. **log4j.jar**: 这是Log4j的主要库文件,包含了Log4j的API和实现。开发者将此jar包引入项目中,就可以使用Log4j提供的各种日志记录功能。新版本和旧版本的log4j.jar可能存在功能更新、性能优化、安全修复等差异,...

    spring-log4j.xml

    log4j.xml配置范例log4j.xml配置范例log4j.xml配置范例log4j.xml配置范例log4j.xml配置范例

    log4j2.xml文件

    log4j2.xml文件

    log4j-1.2.17.jar下载

    Log4j的核心配置文件为“log4j.properties”或“log4j.xml”。通过这个文件,我们可以定义日志的输出格式、输出目的地(如控制台、文件、数据库等)以及日志过滤规则。例如,以下是一个简单的配置示例: ```...

    log4j2-所需jar包+配置详解(详细)

    关于配置文件的名称以及在项目中的存放位置  log4j 2.x版本不再支持像1.x中的....如果本地要测试,可以把log4j2-test.xml放到classpath,而正式环境使用log4j2.xml,则在打包部署的时候不要打包log4j2-test.xml即可。

    log4j-1.2.15.jar

    2. **配置文件**:创建log4j.properties或log4j.xml配置文件,设置日志级别、Appender、Layout和Filter。 3. **编程接口**:在代码中使用Logger接口创建并初始化logger对象,然后调用相应的方法(如debug(), info()...

    log4j.xml template

    一个比较通用的log4j.xml配置模板

Global site tag (gtag.js) - Google Analytics