博客
关于我
Log4j.xml和Log4j2.xml的简单认识 - log4j2/log4j的区别
阅读量:804 次
发布时间:2023-02-06

本文共 1264 字,大约阅读时间需要 4 分钟。

有时在项目中导入log4j的jar包,并配置log4j.xml或者是log4j2.xml后,在代码中引入log4j的API,并不能成功地将日志写入控制台或文件中。这一问题可能出现在配置或依赖管理上。以下是经过实践验证的解决方案。

首先,需要了解log4j的日志级别体系。log4j支持多个日志级别,包括trace、debug、info、warn、error和fatal。这些级别之间具有包含关系,意味着如果将日志级别设置为trace,所有大于等于trace级别的日志都会被记录。

在实际项目中,建议采用以下配置方式:

使用log4j2.xml配置

  • 导入依赖:确保在项目中引入了log4j2的核心包log4j-core.2.1.jar和API包log4j-api.2.1.jar。这些依赖会自动引入必要的日志管理器类。

  • 创建日志配置文件:在log4j2.xml文件中进行配置。以下是一个示例配置:

    1. 使用正确的日志管理器类:在代码中使用org.apache.logging.log4j.LogManagerLogger类。确保使用以下导入:
    2. import org.apache.logging.log4j.LogManager;import org.apache.logging.log4j.Logger;
      1. 获取应用程序日志器:通过LogManager获取应用程序的日志器实例:
      2. protected static Logger logger = LogManager.getLogger(BaseTestPlan.class);

        通过以上配置和代码,日志将会被成功地写入控制台和指定的文件中。如果在启动时遇到类似下面的异常:

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

        可以将YYYYMMddHHmmss中的Y改为小写y,即yyyyMMddHHmmss进行尝试。

        通过以上方法,可以有效地解决log4j日志输出问题,确保日志能够正确地记录到控制台或文件中。

    转载地址:http://kdufk.baihongyu.com/

    你可能感兴趣的文章
    Text-to-Image with Diffusion models的巅峰之作:深入解读 DALL·E 2
    查看>>
    TCP基本入门-简单认识一下什么是TCP
    查看>>
    tableviewcell 中使用autolayout自适应高度
    查看>>
    Orcale表被锁
    查看>>
    svn访问报错500
    查看>>
    org.apache.ibatis.exceptions.TooManyResultsException: Expected one result (or null) to be returned
    查看>>
    org.apache.ibatis.type.TypeException: Could not resolve type alias 'xxxx'异常
    查看>>
    org.apache.poi.hssf.util.Region
    查看>>
    org.apache.xmlbeans.XmlOptions.setEntityExpansionLimit(I)Lorg/apache/xmlbeans/XmlOptions;
    查看>>
    org.apache.zookeeper.KeeperException$ConnectionLossException: KeeperErrorCode = ConnectionLoss for /
    查看>>
    org.hibernate.HibernateException: Unable to get the default Bean Validation factory
    查看>>
    org.hibernate.ObjectNotFoundException: No row with the given identifier exists:
    查看>>
    org.springframework.orm.hibernate3.support.OpenSessionInViewFilter
    查看>>
    org.springframework.orm.hibernate3.support.OpenSessionInViewFilter
    查看>>
    org.springframework.web.multipart.MaxUploadSizeExceededException: Maximum upload size exceeded
    查看>>
    org.tinygroup.serviceprocessor-服务处理器
    查看>>
    org/eclipse/jetty/server/Connector : Unsupported major.minor version 52.0
    查看>>
    org/hibernate/validator/internal/engine
    查看>>
    SQL-36 创建一个actor_name表,将actor表中的所有first_name以及last_name导入改表。
    查看>>
    ORM sqlachemy学习
    查看>>