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

    你可能感兴趣的文章
    mysql5.7 安装版 表不能输入汉字解决方案
    查看>>
    MySQL5.7.18主从复制搭建(一主一从)
    查看>>
    MySQL5.7.19-win64安装启动
    查看>>
    mysql5.7.19安装图解_mysql5.7.19 winx64解压缩版安装配置教程
    查看>>
    MySQL5.7.37windows解压版的安装使用
    查看>>
    mysql5.7免费下载地址
    查看>>
    mysql5.7命令总结
    查看>>
    mysql5.7安装
    查看>>
    mysql5.7性能调优my.ini
    查看>>
    MySQL5.7新增Performance Schema表
    查看>>
    Mysql5.7深入学习 1.MySQL 5.7 中的新增功能
    查看>>
    Webpack 之 basic chunk graph
    查看>>
    Mysql5.7版本单机版my.cnf配置文件
    查看>>
    mysql5.7的安装和Navicat的安装
    查看>>
    mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
    查看>>
    Mysql8 数据库安装及主从配置 | Spring Cloud 2
    查看>>
    mysql8 配置文件配置group 问题 sql语句group不能使用报错解决 mysql8.X版本的my.cnf配置文件 my.cnf文件 能够使用的my.cnf配置文件
    查看>>
    MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
    查看>>
    MYSQL8.0以上忘记root密码
    查看>>
    Mysql8.0以上重置初始密码的方法
    查看>>