博客
关于我
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/

    你可能感兴趣的文章
    Mysql: 对换(替换)两条记录的同一个字段值
    查看>>
    mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
    查看>>
    MYSQL:基础——3N范式的表结构设计
    查看>>
    MYSQL:基础——触发器
    查看>>
    Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
    查看>>
    mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
    查看>>
    mysqldump 参数--lock-tables浅析
    查看>>
    mysqldump 导出中文乱码
    查看>>
    mysqldump 导出数据库中每张表的前n条
    查看>>
    mysqldump: Got error: 1044: Access denied for user ‘xx’@’xx’ to database ‘xx’ when using LOCK TABLES
    查看>>
    Mysqldump参数大全(参数来源于mysql5.5.19源码)
    查看>>
    mysqldump备份时忽略某些表
    查看>>
    mysqldump实现数据备份及灾难恢复
    查看>>
    mysqldump数据库备份无法进行操作只能查询 --single-transaction
    查看>>
    mysqldump的一些用法
    查看>>
    mysqli
    查看>>
    MySQLIntegrityConstraintViolationException异常处理
    查看>>
    mysqlreport分析工具详解
    查看>>
    MySQLSyntaxErrorException: Unknown error 1146和SQLSyntaxErrorException: Unknown error 1146
    查看>>
    Mysql_Postgresql中_geometry数据操作_st_astext_GeomFromEWKT函数_在java中转换geometry的16进制数据---PostgreSQL工作笔记007
    查看>>