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

    你可能感兴趣的文章
    php版本微信公众号开发
    查看>>
    php版的微信公众号开发演示
    查看>>
    php生成html文件的多种方法介绍
    查看>>
    php生成二维码到图片上
    查看>>
    php生成二维码并下载图片(适应于框架)
    查看>>
    PHP生成及获取JSON文件的方法
    查看>>
    PHP生成唯一不重复的编号
    查看>>
    PHP生成器-动态生成内容的数组
    查看>>
    PHP的ip2long和long2ip升级函数
    查看>>
    PHP的json_encode函数应用到微信接口问题(include \uxxxx will create fail)
    查看>>
    PHP的readfile函数和file_get_contents函数错误: Unable to find the wrapper "https"
    查看>>
    php的web路径获取
    查看>>
    php的一些小笔记--字符串
    查看>>
    php的几种运行模式CLI、CGI、FastCGI、mod_php
    查看>>
    php的四大特性八大优势
    查看>>
    RabbitMQ
    查看>>
    PHP的威胁函数与PHP代码审计实战
    查看>>
    PHP的引用举例
    查看>>
    PHP相关代码
    查看>>
    RabbitMQ
    查看>>