`
gao2008ss
  • 浏览: 9840 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

Spring 5.0集成log4j2

 
阅读更多

Spring 5.0发布一段时间了,最近将项目从Spring 4.3升级到Spring 5.0,Spring 4.3集成log4j所用的类org.springframework.web.util.Log4jConfigListener在Spring 5.0版本已经删除,而且log4j 1.x版已经不再更新。我们将log4j-1.x升级为log4j-2.x

 

先引入log4j 2的三个jar包

log4j-api-2.10.0.jar

log4j-core-2.10.0.jar

log4j-web-2.10.0.jar

 

项目下的web.xml文件加入,本设置让日志文件使用${web:rootDir}输出到web目录下

<context-param>
    <param-name>log4jContextName</param-name>
    <param-value>myApplication</param-value>
</context-param>

 

log4j 2支持JSON、YAML、properties、XML四种配置方式,我们按老规据使用 properties 配置 Log4j2

在项目的src目录下加入log4j2.properties文件,spring 5.0默认会自动加载该文件

 

# 设定Log4j2内部的日志级别,有效值:trace, debug, info, warn, error, fatal。只对Log4j本身的事件有效,可以不设置,当设置成trace时,会看到log4j2内部各种详细输出
status = fatal

# 配置的名称
name =PropertiesConfig


appenders = console,I


#控制台类型的日志输出源
appender.console.type = Console
#输出源的名称
appender.console.name = consoleLog
#输出布局类型
appender.console.layout.type = PatternLayout
#输出模板
appender.console.layout.pattern = %m%n
appender.console.target = System_out  



# 文件滚动记录类型的日志输出源
appender.I.type = RollingFile
# 当前滚动输出源的名称,以便在Logger的配置项中能够调用
appender.I.name = InfoRollingFile
# 当前正在操作的日志文件的文件名
appender.I.fileName = ${web:rootDir}/WEB-INF/log/info.log
# 归档后的日志文件的文件名格式,其中`%d{yyyy-MM-dd-HH}`用来自动填充日期
appender.I.filePattern = ${web:rootDir}/WEB-INF/log/info_%d{MM-dd}_%i.log
# 滚动记录输出源布局类型
appender.I.layout.type = PatternLayout
# 滚动记录输出模板
appender.I.layout.pattern = %-d{yyyy-MM-dd HH:mm:ss} [ %p ] [ %c ] %m%n
# 指定记录文件的封存策略,该策略主要是完成周期性的日志文件封存工作
appender.I.policies.type = Policies
# 基于时间进行日志的切割
appender.I.policies.time.type = TimeBasedTriggeringPolicy
# 切割的间隔为1月, 即每天进行一次日志的归档,如果filePattern中配置的文件重命名规则是${web:rootDir}/WEB-INF/log/info_%d{yyyy-MM-dd HH-mm}-%i,最小的时间粒度是mm,即分钟,TimeBasedTriggeringPolicy指定的size是1,结合起来就是每2分钟生成一个新文件。如果改成%d{yyyy-MM-dd HH},最小粒度为小时,则每2个小时生成一个文件。
appender.I.policies.time.interval = 1
# 修正时间范围, 从0时开始计数。若modulate=true,则封存时间将以0点为边界进行偏移计算。比如,modulate=true,interval=4hours,那么假设上次封存日志的时间为03:00,则下次封存日志的时间为04:00,之后的封存时间
appender.I.policies.time.modulate = true
# 基于日志文件体积的触发策略
appender.I.policies.size.type = SizeBasedTriggeringPolicy
# 当日志文件体积大于size指定的值时,触发Rolling
appender.I.policies.size.size=50M
# 文件封存的覆盖策略(RolloverStrategy)
appender.I.strategy.type = DefaultRolloverStrategy
# 生成分割(封存)文件的个数
appender.I.strategy.max = 100

# 根日志,所有日志的父节点 级别顺序(低到高):all < trace <debug < info < warn < error < fatal <off
rootLogger.level = debug
rootLogger.appenderRef.I.ref = InfoRollingFile
rootLogger.appenderRef.I.level = info

# 关联名称为consoleLog的输出源  注意consolelog小写
rootLogger.appenderRef.consolelog.ref = consoleLog
# 生产环境设为off关闭控制台日志输出
rootLogger.appenderRef.consolelog.level = debug

 

 

配置完成后写个类测试一下

 

 

 

 

import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
public class TestClass{
	public static final Logger logger = LogManager.getLogger(TestClass.class);     
	public void test(){
		logger.info("信息....");
	}
}

 

0
0
分享到:
评论

相关推荐

    Spring 5.0集成log4j2日志管理的示例代码

    Spring 5.0集成log4j2日志管理的示例代码 本篇文章主要介绍了Spring 5.0集成log4j2日志管理的示例代码,旨在帮助读者快速掌握log4j2在Spring 5.0框架下的配置和使用。 首先,需要引入log4j 2的三个jar包:log4j-...

    MAVEN(spring5.0)全套依赖

    在SLF4J的支持下,我们可以轻松地将Log4j作为日志实现嵌入到Spring 5.0项目中。 ### MyBatis MyBatis是一个优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射。MyBatis避免了几乎所有的JDBC代码和手动设置...

    SSH整合jar包-spring5.0+hibernate5.1+struts2.5

    4. 其他可能的依赖库,如log4j、commons-logging、slf4j等 使用这个SSH整合jar包,开发者可以快速搭建一个基于SSH的项目结构,节省了单独下载和配置每个框架的时间。同时,由于这些jar文件已经经过了"使用测试通过...

    spring5.0全套jar包

    这个"spring5.0全套jar包"包含了众多与开发相关的库,使得开发者能够快速集成并构建基于Spring的应用。下面我们将深入探讨这些jar包以及它们在IT开发中的作用。 1. **Common系列**:这通常指的是Apache Commons项目...

    sturts2+spring2.5+hibernate3.5+c3p0+log4j整合示例项目

    本项目是一个基于Struts2、Spring2.5、Hibernate3.5的整合示例,其中还引入了c3p0作为数据库连接池,并使用了日志工具Log4j。这个项目的目的是帮助开发者理解如何在实际开发中快速、有效地整合这四个关键组件,从而...

    SpringMVC项目(MongoDB3.0)

    在本项目中,我们主要探讨的是如何在Spring MVC框架下集成MongoDB 3.0数据库,同时利用log4j2进行日志管理,并且运用注解进行程序的简化与优化。下面将对这些核心知识点进行详细阐述。 首先,Spring MVC是Spring...

    java8源码-Spring4Hibernate5Maven:基于spring4.2.4+Hibernate5.0.7final搭建的Mave

    Eclipse搭建Maven工程集成Spring4+Hibernate5+log4j2 这里将以Eclipse搭建Maven工程集成Spring4生成的项目为基础,集成Hibernate5.0.7final。 亲可以参考: 1、Maven安装以及在eclipse中的配置 2、Eclipse中使用...

    Spring Project Bulder

    这是一个基于b/s模式的spring web工程代码生产工具.... &lt;br&gt;涉及技术:spring mvc,spring ioc+aop,spring dao+jdbc/ibatis/hibernate,log4j,jsp/velocity/freemareker &lt;br&gt;环境:tomcat+jdk1.50+mysql5.0测试成功

    Learning_Spring_Boot_2.0.rar

    书中可能会讨论如何使用Logback、Log4j2等日志库,以及如何实现日志级别控制和日志文件滚动。 总而言之,《Learning Spring Boot 2.0》这本书将全面覆盖Spring Boot 2.0的核心概念、新特性以及最佳实践,无论你是...

    注解方式搭建springmvc+spring+ibatis

    在这里,我们设置了应用的显示名称和描述,定义了ServletContext初始化参数,如log4j配置位置和Spring上下文配置的位置。此外,还配置了字符编码过滤器以确保数据不出现乱码问题。最后,配置了Spring Security过滤器...

    框架集合错误解决方案

    log4j.appender.console.layout=org.apache.log4j.PatternLayout log4j.appender.console.layout.ConversionPattern=%-5p %d{yyyy-MM-dd HH:mm:ss} [%F,%L] -%m%n log4j.appender.file=org.apache.log4j....

    SpringMVC+Mybatis整合ExtJs5.0

    日志记录通常采用Log4j或Logback;异常处理则可以通过Spring的@ControllerAdvice和@ExceptionHandler进行全局异常处理。 综上所述,"SpringMVC+Mybatis整合ExtJs5.0"的项目结合了后端的强大处理能力和前端的用户...

    图解SSH三框架整合

    log4j.appender.stdout.layout=org.apache.log4j.PatternLayout log4j.appender.stdout.layout.ConversionPattern=%c{1}-%m%n ``` 其中,`info` 是日志级别,可以根据实际需求调整为 `debug` 或其他级别。 #### 四...

    springboot.zip

    项目使用jdk1.8,MySQL8.1.12版本,Tomcat8,spring,springboot,mybatis,redis5.0版本,log4j构建而成,如果后期项目需要则需要加入shiro框架集成 包括控制层和视图均已配置完成,dao层操作已配合redis实现,包含...

    MyEclipse配置

    2. **优化日志配置**:使用最新版本的Log4j可以提高日志记录的效率和灵活性。 #### 九、总结 通过上述步骤,我们成功地在MyEclipse环境下配置了Struts、Hibernate与Spring三个框架,并实现了它们之间的整合。这种...

    北大青鸟5.0项目,电影院售票系统

    使用Log4j或Logback记录系统日志,便于调试和问题排查。 9. **测试与性能优化**:单元测试确保每个模块的功能正确,集成测试检查各组件协同工作。性能测试评估系统的负载承受能力,优化SQL查询、缓存策略以提高系统...

    基于Annotation的Struts2.0+Hibernate3.3+Spring2.5图文教程整合开发.doc

    - 解决`NoClassDefFoundError`错误,需要添加slf4j-log4j12.jar和log4j.jar,这两个包是Hibernate3.3运行时所需的日志库。 5. **Hibernate Annotation的使用**: - 示例代码展示了如何使用注解定义实体类User,如...

    Accp5.0一期Java购物系统代码

    10. **日志记录**:通过Log4j或SLF4J记录系统运行日志,便于后期排查问题。 11. **部署与服务器配置**:如Tomcat或Jetty服务器的配置,以及MySQL或Oracle数据库的设置。 通过对这个"ShopManagementSystem"的深入...

    spring-framework-2.5.1

    - **v512工作室_刘伟_Hibernate与Struts2和Spring组合开发.pdf**:这份文档可能是关于如何在Spring 2.5.1环境下整合Hibernate和Struts2的实践指南,对于学习三者结合的开发非常有帮助。 - **changelog.txt**:记录...

    搭建spring mvc + hibernate

    fileupload.jar`、`commons-logging.jar`、`commons-logging-1.0.4.jar`、`commons-validator.jar`、`dom4j-1.6.1.jar`、`ehcache-1.2.jar`、`jakarta-oro.jar`、`jstl.jar`、`jta.jar`、`log4j-1.2.11.jar`、`mail....

Global site tag (gtag.js) - Google Analytics