欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

spring中的log4j简单配置

程序员文章站 2022-04-19 22:34:12
...

1. 内容简介

本帖的主要内容在于介绍在spring中通过log4j实现基础日志打印。

2. 所需组件

2.1 所需jar包

log4j-1.2.17.jar

commons-logging-1.2.jar

2.2 所需的配置文件

1. spring基本配置文件,类似 web.xml、applicationcontext.xml等

2. log4j的配置文件,log4j.xml 文件

3. 必要组件的配置

3.1 log4j.xml的配置

在log4j.xml*分为两个部分:1.<appender></appender>,主要用于指定日志文件路径和名字(见下面代码中的注释)以及日志输出的方式;2.<logger></logger>部分用于给java代码提供调用点,相当于是一个对外的接口。

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration PUBLIC "-//LOGGER"
"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/">
    <!-- 文件中指定重写ProbeRollingFileApp,其实可以不重写而直接用 -->
    <appender name="CHAMTLOG" class = "com.china.domain.logs.ProbeRollingFileApp">
        <!-- 用于指定日志文件的路径和名字,其中 ${catalia.home}是tomcat底下/conf/所在路径 -->
        <param name="File" value="${catalina.home}/logs/chamt.log"/>
        <param name="MaxFileSize"  value="10MB"/>
        <param name="MaxBackupIndex" value="20MB"/>
        <layout class="org.apache.log4j.PatternLayout">
            <!-- 用于指定日志文件中各个打印的格式 -->
            <param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss:SSS} [%-5p][method:%l][%t]%n%m%n%n"/>
        </layout>
    </appender>
    
    <!-- 在代码中关联了该name,则用该节点指定的appender进行打印 -->
    <logger name="test.log4j.test8.UseLog4j" additivity="false">
        <!-- 指定打印的级别,在该例中,只有大于等于WARN级别的日志才会被打印 -->
        <level value ="WARN"/>
        <appender-ref ref="CHAMTLOG"/>
    </logger>
    
    <!-- 默认打印的appender -->
    <root>
        <level value ="INFO"/>
        <appender-ref ref="CHAMTLOG"/>
    </root>

</log4j:configuration>

关于ProbeRollingFileApp文件的说明,其实没有必要重写RollingFileAppender类而可以直接用,之所以在本文中要重新,是考虑到打印过程中句柄失效的场景,在这种情况下需要重新建立句柄以实现继续打印。其代码如下所示:

package com.china.domain.logs;

import java.io.File;

import org.apache.log4j.RollingFileAppender;
import org.apache.log4j.spi.LoggingEvent;

public class ProbeRollingFileApp extends RollingFileAppender {

	protected void subAppend(LoggingEvent event) {  
		
		/**
		 * 这段代码主要考虑一种情况:当句柄不存在的时候重新建立句柄以继续打印
		 */
		if(!new File(this.fileName).exists()) {
			try {
				super.setFile(this.fileName, this.getAppend(), this.bufferedIO, this.bufferSize);
			}catch(Exception e) {
				System.out.println(e.toString());
			}
		}
        super.subAppend(event);  
       
    }  
}

3.2 在web.xml文件中的配置

在web.xml中的配置主要分为以下几个方面:1. 指定log4j.xml文件的位置;2. 指定扫描的间隔时间;3. 配置log4j的监听器。

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
	
	<context-param>
	    <param-name>contextConfigLocation</param-name>
	     <param-value>/WEB-INF/applicationContext.xml</param-value>
	</context-param>
	
	<!-- 指定log4j.xml文件的位置 -->
	<context-param>
        <param-name>log4jConfigLocation</param-name>
        <param-value>/WEB-INF/log4j.xml</param-value>
    </context-param>
    
    <!-- 指定日志重新扫描的时间,服务器每隔该指定时间对该文件进行重新扫描。实现修改日志级别后不重启tomcat也可生效 -->
    <context-param>
        <param-name>log4jRefreshInterval</param-name>
        <param-value>10000</param-value>
    </context-param>
    
    <!-- log4j 监听器 -->
    <listener>
        <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
    </listener>

	<listener>
	    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
	</listener>
	
	<listener>
	    <listener-class>org.springframework.web.context.request.RequestContextListener</listener-class>
	</listener>
	
	<servlet>
	    <servlet-name>dispatcher</servlet-name>
	    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
	    <load-on-startup>3</load-on-startup>
	</servlet>
	
	<servlet-mapping>
	    <servlet-name>dispatcher</servlet-name>
	    <url-pattern>*.html</url-pattern>
	</servlet-mapping>
	
</web-app>	

3.3 在代码中调用

1. 创建一个Logger,指定引用log4j.xml中<logger/>节点的接口,一般来说,都是填写 a.class(如下例),则会关联到<root/>节点

2. 在需要打印的地方选择级别进行打印

@Controller
public class LoginController 
{		
	private Logger logger = Logger.getLogger(LoginController.class);
	
	@RequestMapping(value="/index.html")
	public String loginPage()
	{ 
		logger.error("++++++++++++++++++++");
		System.out.println("+++++++"+"china"+"+++++++++");
		return "login";
	}
}

3.4 打印结果展示

运行tomcat之后,会在apache-tomcat-7.0.82\logs路径下找到 chamt.log(在log4j.xml文件中所指定)文件并在文件中找到相关的打印。