spring中的log4j简单配置

0 篇文章 0 订阅

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文件中所指定)文件并在文件中找到相关的打印。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring是一个开源的Java应用框架,它提供了一种配置方式可以帮助我们在应用使用log4j进行日志记录。log4j是一个广泛应用的Java日志工具,它能够帮助我们在代码输出日志信息。 在Spring配置文件,我们可以使用<logging:configurer>元素来配置log4j。这个元素可以帮助我们加载log4j配置文件,并将日志输出到指定的目标。 首先,我们需要在Spring配置文件引入命名空间<xmlns:logging="http://www.springframework.org/schema/logging">。然后,我们可以在<beans>元素使用<logging:configurer>元素来配置log4j。 在<logging:configurer>元素,我们可以设置以下属性来配置log4j: - level:指定日志记录的级别,如DEBUG、INFO、WARN、ERROR等。 - location:指定log4j配置文件位置。 - watch:指定是否在配置文件发生变化时自动重新加载log4j配置。 除了配置文件的元素,我们还可以在代码使用注解来配置log4j。通过在类上使用@Log4j注解,我们可以自动使用log4j来记录日志。同时,我们还可以在方法上使用@Log注解来记录方法的执行流程。 总体而言,Spring配置方式可以帮助我们更加灵活地使用log4j进行日志记录。通过配置文件和注解,我们可以指定日志的级别、输出位置和自动加载,从而更好地满足应用的需求。同时,Spring还提供了一些与日志相关的工具类和接口,帮助我们更加方便地使用log4j。通过合理配置和使用log4j,我们可以更好地监控和调试应用,提高应用的稳定性和可维护性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值