0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

log4j日志框架分析

汽车电子技术 来源:Java烂笔头 作者:小週 2023-02-28 14:32 次阅读


日志很重要!!!

//log4j是什么?

log4j是Apache下的一款开源的日志框架,能够满足我们在项目中对于日志记录的需求。log4j提供了简单的API调用,强大的日志格式定义以及灵活的扩展性。使用者可以自己定义Appender来满足对于日志输出的需求。在系统中对于记录日志的需求并不单纯。

首先,希望日志能持久化到磁盘,最基本的就是能够保存到文件中;

其次,希望在开发和生产环境中记录的日志并不相同,明显开发环境的日志记录会更多方便调试,但放到生产环境下大量的日志很容易会撑爆服务器,因此在生产环境希望只记录重要信息

基于不同的目的,System.out.println不能直接满足使用者的需求,因此应该选择功能更强的日志框架。而log4j是apache下一款著名的开源日志框架。

//为什么需要日志?

①异常的场景

产品开发、系统运维(升级、日常管理等)

②时间成本

快速、高效

③人力成本

简化、降低难度

//日志给谁用?

pYYBAGP9n36ARCiXAAGH2W3m17o808.png

//日志什么时候用?

日志作为一种调试利器,可以帮助我们观察软件运行时内部结构和状态,辅助开发。日志文件分析已成为大型软件项目中代码调试的主要手段

①软件测试时

软件测试过程中,通过Debug或Trace信息,可以确认功能的实现原理及正确性。

②软件运维时

已发布运行的软件,当某个功能出现异常时,我们无法像开发环境一样进行调试找原因,能留给我们的就只有日志系统。如网管的配置下载问题。

③学习软件时

熟悉一个陌生软件系统时,日志能够提供很多线索给我们去了解软件的架构和实现逻辑。

//日志什么时候该记录?

①模块的启动与结束

需要对模块的启动和结束进行监控,从而知道模块是否正常加载或正常退出。比如网管ICE服务的OnClientInitMe等函数。

②用户登录及操作

需要记录用户何时登录、登出以及做了哪些操作,方便审计。比如网管的安全日志和操作日志。

③异常信息

所有捕获异常的位置均应当记录异常内容日志,所有与系统软件预期不符的地方都要记录日志。

④软件的关键方法

需要记录软件系统的一些关键性操作,它是衡量系统正常运行的重要指标。比如业务/配置增删改、激活、去激活等关键操作。

//日志有几个等级?

日志等级:OFF > FATAL > ERROR > WARN > INFO > DEBUG > TRACE > ALL。

通常以下几种:TRACE、DEBUG、INFO、WARN、ERROR

①TRACE :细致入微,可以用于开发过程中追踪bug 。

②DEBUG:系统调试信息,通常用于开发过程中对系统运行情况的监控,在实际运行环境中不进行输出。

③INFO:系统运行的关键性信息,通常用于对系统运行情况的监控。

④WARN:告警信息,系统存在潜在的问题,有可能引起运行异常,但此时并未产生异常。

⑤ERROR:系统错误信息,需要进行及时处理和优化。

等级

目的

阶段

对象

程度

ERROR

告警

运行

用户

准确/严重

WARN

提醒

运行/使用

用户

准确

INFO

说明

使用

运维

简洁

DEBUG

详解

开发调试

维护/开发

详细清楚

TRACE

研究

调试/学习

开发/研发

细致入微

//使用日志该注意什么?

①粒度适中

②写有意义的log

③不同场景选择正确的日志级别

④日志信息可理解性

⑤日志语言选择英文

日志细节决定系统成败!

//log4j日志该如何配置使用?

配置

在项目资源配置文件夹新建log4j.properties

### 设置###
log4j.rootLogger = debug,stdout,debugLog,infoLog,errorLog

### 输出信息到控制台 ###
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern = [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n

### 输出DEBUG 级别以上的日志 ###
log4j.appender.debugLog = org.apache.log4j.DailyRollingFileAppender
log4j.appender.debugLog.File =logs/debug/log.log
log4j.appender.debugLog.DatePattern = '.'yyyy-MM-dd-HH-mm'.log'
log4j.appender.debugLog.Append = true
log4j.appender.debugLog.Threshold = DEBUG
log4j.appender.debugLog.layout = org.apache.log4j.PatternLayout
log4j.appender.debugLog.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n

### 输出INFO 级别以上的日志 ###
log4j.appender.infoLog = org.apache.log4j.DailyRollingFileAppender
log4j.appender.infoLog.File =logs/info/log.log
log4j.appender.infoLog.DatePattern = '.'yyyy-MM-dd-HH-mm'.log'
log4j.appender.infoLog.Append = true
log4j.appender.infoLog.Threshold = INFO
log4j.appender.infoLog.layout = org.apache.log4j.PatternLayout
log4j.appender.infoLog.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n

### 输出ERROR 级别以上的日志 ###
log4j.appender.errorLog = org.apache.log4j.DailyRollingFileAppender
log4j.appender.errorLog.File =logs/error/log.log
log4j.appender.errorLog.DatePattern = '.'yyyy-MM-dd-HH-mm'.log'
log4j.appender.errorLog.Append = true
log4j.appender.errorLog.Threshold = ERROR
log4j.appender.errorLog.layout = org.apache.log4j.PatternLayout
log4j.appender.errorLog.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} 

注意:log4j.properties文件一定存放在资源文件夹中,否则项目无法识别调用

设置输出内容

编写日志输出内容

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class TestLog4j {

    private static  Logger logger = LoggerFactory.getLogger(TestLog4j.class);

    public static void main(String[] args) {

        System.out.println("This is println message.");
        // 记录debug级别的信息
        logger.debug("This is debug message.");
        // 记录info级别的信息
        logger.info("This is info message.");
        // 记录error级别的信息
        logger.error("This is error message.");
    }
}

测试结果

项目结构

pYYBAGP9n8CAaJOJAAGVqIfb-Rc469.png

运行结果

日志信息输出到控制台

pYYBAGP9n8iAOrcXAAEGmjA40cU589.png

日志信息保存到本地

logs文件夹系统会自动生成,无需新建

pYYBAGP9n9OAFxpNAAEIeb63AQc990.png

debug

pYYBAGP9n9yAceceAABXXfvXvqQ753.png

error

poYBAGP9n-OASkweAAAWGwKUNlc643.png

info

pYYBAGP9n-qAeRlwAABXx2baLEg563.png


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 框架
    +关注

    关注

    0

    文章

    297

    浏览量

    17045
  • 日志
    +关注

    关注

    0

    文章

    126

    浏览量

    10526
  • Apache
    +关注

    关注

    0

    文章

    64

    浏览量

    12313
收藏 人收藏

    评论

    相关推荐

    【嵌入式SD NAND】基于FATFS/Littlefs文件系统的日志框架实现

    设备的运行数据。日志文件不同于其他功能,其往往需要具备几个基本特性需求: 单个文件大小限制 日志总大小空间占用限制 自动循环覆盖 网上也有一些开源的日志框架,如
    发表于 03-14 18:12

    logcat如何查看Andriod log系统日志

    logcat会输出系统哪些信息呢?如何学习logcat命令?logcat如何查看Andriod log系统日志?如何查看Andriod log系统日志
    发表于 03-03 06:15

    slf4j打印日志必须的三个依赖包相关资料推荐

    1、slf4j打印日志必须的三个依赖包  日志相关包 slf4j打印日志必须的三个依赖包  slf4j
    发表于 10-19 14:57

    STM32Cube工具的log4j漏洞CVE-2021-44228和CVE-2021-45046有何影响?

    STM32Cube工具的log4j漏洞CVE-2021-44228和CVE-2021-45046有何影响?
    发表于 12-07 07:02

    java 日志框架Spring Boot分析

    应用程序中输出相应的日志。 在传统Java应用程序中,我们一般会使用类似Log4j这样的日志框架来输出日志,而不是直接在代码中通过Syste
    发表于 09-28 14:58 0次下载

    logback异常输出详细信息(调用堆栈)分析

     Logback是一个开源的日志组件,是log4j的作者开发的用来替代log4j的。logback由三个部分组成,logback-core, logback-classic, logback-access。其中logback-c
    发表于 11-28 16:31 7870次阅读

    Java日志框架中的王者是谁

    ,远不及Apache 的新一代日志框架 - Log4j 目前来看,Log4j2 就是王者,其他日志框架
    的头像 发表于 10-13 09:12 1194次阅读

    嵌入式log打印格式输出技巧

    嵌入式log打印格式输出技巧Log 信息格式条件编译可变参数宏C标准中一些预定义的宏格式输出16进制数组Log 信息格式参考目前主流嵌入式、安卓等输出方式:[日志级别] 文件名 :
    发表于 10-20 21:06 5次下载
    嵌入式<b class='flag-5'>log</b>打印格式输出技巧

    使用Keysight免费评估Log4j/Log4Shell零日漏洞

    在过去72小时左右的时间里,网络安全领域的大多数人已经意识到Log4j/Log4Shell零日漏洞及其对大多数web服务器、云应用程序、互联网设备和嵌入式设备的广泛影响。你可以阅读CVE-2021-44228中记录的所有血淋淋的细节,但底线是:这可能非常非常糟糕。
    的头像 发表于 12-21 10:50 1267次阅读

    针对大量log日志快速定位错误地方

    用 grep 拿到的日志很少,我们需要查看附近的日志。我是这样做的,首先: cat -n test.log | grep “关键词” 得到关键日志的行号
    的头像 发表于 04-21 09:22 472次阅读

    Spring Boot的日志框架使用

    目前市面上常见的日志框架有:slf4j(Simple Logging Facade for Java)、logback、log4jlog4j2、commons-logging(Spr
    的头像 发表于 06-02 10:59 691次阅读
    Spring Boot的<b class='flag-5'>日志</b><b class='flag-5'>框架</b>使用

    服务器log日志大,掌握这些可正确快速定位错误!

    针对大量log日志快速定位错误地方
    的头像 发表于 06-05 18:14 436次阅读

    基于Rust的Log日志库介绍

    了一种简单的方法来实现日志记录,本文将介绍如何使用Rust的Log库作为日志门面,并结合env_logger和log4rs两个日志库的实战用
    的头像 发表于 09-19 14:49 2142次阅读

    保护Log4j日志中的敏感数据,两步搞定!

    log4j在准备添加日志消息时调用此方法。在MaskingAppender类中,我们覆盖这个方法来拦截日志消息,使用maskSensitiveData()方法对敏感数据应用masking,然后将修改后的消息传递给超类的appen
    的头像 发表于 10-18 16:03 309次阅读

    Log4cpp优势及优点

    命令行、文件、回卷文件、内存、syslog服务器、Win事件日志等; 可以动态控制日志记录级别,在效率和功能中进行调整; 所有配置可以通过配置文件进行动态调整; 多语言支持,包括Java(log4j
    的头像 发表于 11-09 14:27 274次阅读
    <b class='flag-5'>Log</b>4cpp优势及优点