log4j日志框架分析及使用教程

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: log4j日志框架分析及使用教程

log4j日志框架分析及使用教程


日志很重要!!!


log4j是什么?


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


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


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


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


为什么需要日志?


①异常的场景


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


②时间成本


快速、高效


③人力成本


简化、降低难度


日志给谁用?

image.png

image.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}  [ %t:%r ] - [ %p ]  %m%n

注意: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.");
    }
}

测试结果

项目结构


image.png


Maven依赖

<dependencies>
            <dependency>
                <groupId>org.slf4j</groupId>
                <artifactId>slf4j-api</artifactId>
                <version>1.7.5</version>
            </dependency>
            <dependency>
                <groupId>org.slf4j</groupId>
                <artifactId>slf4j-log4j12</artifactId>
                <version>1.7.32</version>
            </dependency>
        </dependencies>

运行结果


日志信息输出到控制台


image.png


日志信息保存到本地


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


image.png


debug


image.png


error


image.png


info

image.png


image.pngimage.png

相关实践学习
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
相关文章
|
2月前
|
消息中间件 Java Kafka
搭建ELK日志收集,保姆级教程
本文介绍了分布式日志采集的背景及ELK与Kafka的整合应用。传统多服务器环境下,日志查询效率低下,因此需要集中化日志管理。ELK(Elasticsearch、Logstash、Kibana)应运而生,但单独使用ELK在性能上存在瓶颈,故结合Kafka实现高效的日志采集与处理。文章还详细讲解了基于Docker Compose构建ELK+Kafka环境的方法、验证步骤,以及如何在Spring Boot项目中整合ELK+Kafka,并通过Logback配置实现日志的采集与展示。
738 64
搭建ELK日志收集,保姆级教程
|
7月前
|
存储 运维 监控
SelectDB 实现日志高效存储与实时分析,完成任务可领取积分、餐具套装/水杯/帆布包!
SelectDB 实现日志高效存储与实时分析,完成任务可领取积分、餐具套装/水杯/帆布包!
|
2月前
|
监控 安全 搜索推荐
使用EventLog Analyzer进行日志取证分析
EventLog Analyzer助力企业通过集中采集、归档与分析系统日志及syslog,快速构建“数字犯罪现场”,精准追溯安全事件根源。其强大搜索功能可秒级定位入侵时间、人员与路径,生成合规与取证报表,确保日志安全防篡改,大幅提升调查效率,为执法提供有力证据支持。
139 0
|
2月前
|
缓存 Java 应用服务中间件
Spring Boot配置优化:Tomcat+数据库+缓存+日志,全场景教程
本文详解Spring Boot十大核心配置优化技巧,涵盖Tomcat连接池、数据库连接池、Jackson时区、日志管理、缓存策略、异步线程池等关键配置,结合代码示例与通俗解释,助你轻松掌握高并发场景下的性能调优方法,适用于实际项目落地。
532 5
|
7月前
|
SQL 监控 数据挖掘
SLS 重磅升级:超大规模数据实现完全精确分析
SLS 全新推出的「SQL 完全精确」模式,通过“限”与“换”的策略切换,在快速分析与精确计算之间实现平衡,满足用户对于超大数据规模分析结果精确的刚性需求。标志着其在超大规模日志数据分析领域再次迈出了重要的一步。
561 117
|
4月前
|
监控 安全 NoSQL
【DevOps】Logstash详解:高效日志管理与分析工具
Logstash是ELK Stack核心组件之一,具备强大的日志收集、处理与转发能力。它支持多种数据来源,提供灵活的过滤、转换机制,并可通过插件扩展功能,广泛应用于系统日志分析、性能优化及安全合规等领域,是现代日志管理的关键工具。
730 0
|
6月前
|
自然语言处理 监控 安全
阿里云发布可观测MCP!支持自然语言查询和分析多模态日志
阿里云可观测官方发布了Observable MCP Server,提供了一系列访问阿里云可观测各产品的工具能力,包含阿里云日志服务SLS、阿里云应用实时监控服务ARMS等,支持用户通过自然语言形式查询
823 0
阿里云发布可观测MCP!支持自然语言查询和分析多模态日志
|
5月前
|
人工智能 运维 监控
Aipy实战:分析apache2日志中的网站攻击痕迹
Apache2日志系统灵活且信息全面,但安全分析、实时分析和合规性审计存在较高技术门槛。为降低难度,可借助AI工具如aipy高效分析日志,快速发现攻击痕迹并提供反制措施。通过结合AI与学习技术知识,新手运维人员能更轻松掌握复杂日志分析任务,提升工作效率与技能水平。
|
XML 安全 Java
【日志框架整合】Slf4j、Log4j、Log4j2、Logback配置模板
本文介绍了Java日志框架的基本概念和使用方法,重点讨论了SLF4J、Log4j、Logback和Log4j2之间的关系及其性能对比。SLF4J作为一个日志抽象层,允许开发者使用统一的日志接口,而Log4j、Logback和Log4j2则是具体的日志实现框架。Log4j2在性能上优于Logback,推荐在新项目中使用。文章还详细说明了如何在Spring Boot项目中配置Log4j2和Logback,以及如何使用Lombok简化日志记录。最后,提供了一些日志配置的最佳实践,包括滚动日志、统一日志格式和提高日志性能的方法。
3567 31
【日志框架整合】Slf4j、Log4j、Log4j2、Logback配置模板
|
XML JSON Java
Logback 与 log4j2 性能对比:谁才是日志框架的性能王者?
【10月更文挑战第5天】在Java开发中,日志框架是不可或缺的工具,它们帮助我们记录系统运行时的信息、警告和错误,对于开发人员来说至关重要。在众多日志框架中,Logback和log4j2以其卓越的性能和丰富的功能脱颖而出,成为开发者们的首选。本文将深入探讨Logback与log4j2在性能方面的对比,通过详细的分析和实例,帮助大家理解两者之间的性能差异,以便在实际项目中做出更明智的选择。
1218 3
下一篇
oss云网关配置