使用spring中的Log4jConfigListener有如如下好处:
1. 动态的改变记录级别和策略,不需要重启Web应用,如《Effective Enterprise Java》所说。
2. 把log文件定在 /WEB-INF/logs/ 而不需要写绝对路径。
因为系统把web目录的路径压入一个叫webapp.root的系统变量。这样写log文件路径时不用写绝对路径了.
log4j.appender.logfile.File=${webapp.root}/WEB-INF/logs/myfuse.log
3. 可以把log4j.properties和其他properties一起放在/WEB-INF/ ,而不是Class-Path。
4.log4jRefreshInterval为6000表示开一条watchdog线程每6秒扫描一下配置文件的变化;
在web.xml 添加
<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>WEB-INF/log4j.properties</param-value>
</context-param>
<context-param>
<param-name>log4jRefreshInterval</param-name>
<param-value>6000</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>
在使用spring先后开发了两个模块,单独测试都正常。也先后上线运行,之后发现有个模块在启动Tomcat后总是初始化失败,必须到tomcat管理控制台手动启动。找了半天也没发现原因。后来管理员在每次重启Tomcat后这个模块没有运行导致一堆问题和麻烦,今天特意查看了其他的tomcat日志文件,终于发现了问题所在,原来是Log4jConfigListener。使用它是为了随时调整打印日志的级别而不用重启服务。没想到没有享受到它的便利,反而出了一堆问题,只能怪自己没有稍微仔细研究一下。
web.xml
<context-param>
<param-name>webAppRootKey</param-name>
<param-value>cang.qing6.com.root</param-value>
</context-param>
<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>/WEB-INF/classes/log4j.properties</param-value>
</context-param>
<context-param>
<param-name>log4jRefreshInterval</param-name>
<param-value>6000</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>
<context-param>
<param-name>webAppRootKey</param-name>
<param-value>cang.qing6.com.root</param-value>
</context-param>
<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>classpath:log4j.properties</param-value>
</context-param>
<context-param>
<param-name>log4jRefreshInterval</param-name>
<param-value>6000</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>
log4j.properties配置
layoutPattern=[%d{HH:mm:ss}] %-5p : %m%n
log.file=${message.web.root}/logs/app.log
log4j.appender.logfile=org.apache.log4j.DailyRollingFileAppender
log4j.appender.logfile.File=${log.file}
log4j.appender.logfile.Append=true
log4j.appender.logfile.DatePattern='.'yyyyMMdd
log4j.appender.logfile.layout=org.apache.log4j.PatternLayout
log4j.appender.logfile.layout.ConversionPattern=${layoutPattern}
layoutPattern=[%d{HH:mm:ss}] %-5p : %m%n
log.file=${message.web.root}/logs/app.log
log4j.appender.logfile=org.apache.log4j.DailyRollingFileAppender
log4j.appender.logfile.File=${log.file}
log4j.appender.logfile.Append=true
log4j.appender.logfile.DatePattern='.'yyyyMMdd
log4j.appender.logfile.layout=org.apache.log4j.PatternLayout
log4j.appender.logfile.layout.ConversionPattern=${layoutPattern}
其实需要注意的地方就是应用服务器下有不止一个的应用在使用spring的Log4jConfigListener需要修改web环境中webAppRootKey值(这个值其实是web应用的根目录在环境变量名,这样在log4j配置文件中如果有相对web目录的路径就不用写死了)。
否则两个默认值web.root在环境变量中就会有冲突导致第二个应用启动失败。
相关推荐
在Spring项目中配置log4j是一项基础且重要的工作,它能帮助我们记录应用程序的运行日志,便于调试、排查问题和性能分析。Log4j是一个广泛使用的Java日志框架,提供灵活的日志记录功能。接下来,我们将详细讲解如何在...
Spring框架通过一系列的配置选项来支持Log4J,这些配置通常位于`web.xml`文件中。以下是一些关键的配置参数: 1. **`webAppRootKey`**: - **作用**:指定用于获取Web应用根目录路径的环境变量名称。 - **示例**...
4. **Log4jConfigListener**:这是一个监听器类,属于Spring的一部分,用于初始化Log4j。当Web应用启动时,Spring会自动调用这个监听器,读取配置文件并配置日志系统。 5. **log4j配置文件**:在`log4j.properties`...
spring5取消Log4jConfigListener,运用Log4jServletContextListener代替Log4jConfigListener(log4j2.xml的配置)
4. **Spring Boot**:熟悉其自动配置机制,快速创建独立的Spring应用,并了解Spring Initializr的作用。 5. **数据访问**:学习使用JdbcTemplate、JPA或MyBatis进行数据库操作,以及Spring Data的高级特性,如...
<listener-class>org.springframework.web.util.Log4jConfigListener <param-name>log4jConfigLocation <param-value>/WEB-INF/classes/log4j.properties ``` 这个配置指定了 Log4j 配置文件的位置为 /WEB-...
### log4j的作用及其配置与测试 #### 一、log4j概述 log4j是Apache的一个开源项目,被广泛应用于Java应用的日志记录。它能够帮助开发者在应用程序中记录错误信息、调试信息等,方便后期的问题排查和系统监控。 ###...
<listener-class>org.springframework.web.util.Log4jConfigListener ``` - 或者,如果使用的是Servlet 3.0及以上版本,可以使用以下配置: ```xml <listener-class>org.apache.logging.log4j.web.Log4...
而在SSH(Struts+Spring+Hibernate)框架中集成Log4j,能够更加有效地管理和监控应用运行状态。 #### 二、SSH框架与Log4j集成的优势 在SSH框架中集成Log4j有以下几个显著优势: 1. **动态调整日志级别**:通过...
<listener-class>org.springframework.web.util.Log4jConfigListener 在上面的配置中,我们可以看到,我们使用了 Log4jConfigListener 来初始化 Log4J 日志引擎,并指定了 log4j.properties 文件的路径。 需要...
在本入门例子中,你将学习如何在Spring环境中设置并使用AOP。 首先,我们需要理解AOP的基本概念。在面向对象编程中,业务逻辑代码往往会被一些通用的、非核心的代码(如日志、事务)所穿插,这降低了代码的可读性...
<listener-class>org.springframework.web.util.Log4jConfigListener ``` 完成这些步骤后,当你的应用程序运行时,log4j会根据配置将日志信息输出到指定的文件夹中。这不仅方便了日志的管理和查看,还可以通过...
4. `<listener>`标签引入了`org.springframework.web.util.Log4jConfigListener`监听器,这个监听器会在Web应用启动时读取`log4jConfigLocation`指定的配置文件,并初始化Log4j。 接下来,我们来看`log4j....
<listener-class>org.springframework.web.util.Log4jConfigListener ... ``` 这样,当Tomcat服务器启动时,会自动读取并应用指定的Log4j配置,从而为整个应用提供日志服务。 在Struts2框架中,由于它集成了...
- **Spring集成**:在使用Spring框架的情况下,可以通过Spring的`Log4jConfigListener`来动态加载`log4j.properties`文件。这需要在`web.xml`中进行相应配置: ```xml <param-name>log4jConfigLocation ...
<listener-class>org.springframework.web.util.Log4jConfigListener ``` 这样的整合使得系统能够灵活地处理HTTP请求,同时通过log4J实现详尽的日志记录,对于监控、调试和性能分析都十分有利。在整个过程中,...
org.springframework.web.util.Log4jConfigListener.class org.springframework.web.util.Log4jConfigServlet.class org.springframework.web.util.Log4jWebConfigurer.class org.springframework.web.util....
<listener-class>org.springframework.web.util.Log4jConfigListener <param-name>log4jConfigLocation <param-value>/WEB-INF/classes/log4j2.xml</param-value> <!-- 或者 "log4j2.json" --> ``` 这样就...
采用注解配置SpringMVC,有SpringSecurity,Dao,Controller,Servlet等的样例,部分代码: public void onStartup(ServletContext servletContext) throws ... servletContext.addListener(Log4jConfigListener.class);
<listener-class>org.springframework.web.util.Log4jConfigListener ``` `webAppRootKey`参数用于设置应用的根目录键,Log4jConfigListener则会在启动时寻找log4j.properties或log4j.xml配置文件,从而初始化...