黑豹程序员-架构师学习路线图-百科:Log4j 业务日志代码分离

本文主要是介绍黑豹程序员-架构师学习路线图-百科:Log4j 业务日志代码分离,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 1、什么是Log4j?
  • 2、发明了日志级别
  • 3、为什么要使用Log4j

在这里插入图片描述

1、什么是Log4j?

Log4j是Apache的一个开源项目,它有三大组件:

1、Logger: 日志对象,负责捕捉日志记录信息;

2、Appender: 日志输出目的地,负责把格式好的日志信息输出到指定地方,可以是控制台、磁盘文件等;

3、Layout: 日志格式化器,负责发布不同风格的日志信息;

通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件,甚至是套接口服务器、NT的事件记录器、UNIX Syslog守护进程等;我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程。最令人感兴趣的就是,这些可以通过一个配置文件来灵活地进行配置,而不需要修改应用的代码。

2、发明了日志级别

其中最厉害的莫过于日志的级别的发明

  ALL:打开所有日志;DEBUG:适用于代码调试期间;INFO:适用于代码运行期间;WARN:适用于代码会有潜在错误事件;ERROR:适用于代码存在错误事件;FATAL:适用于严重错误事件;OFF:关闭所有日志;

3、为什么要使用Log4j

在日志体系出现前,java代码调试都是通过 System.out.print(“日志”); 来做的。这样开发者可以通过打印运行时的变量的值,从而观察结果是否和期望是一致的。

但这么做有很多不好的点。
第一、当开发过程中,日志是非常有用的,但当系统稳定运行后,大多日志信息就无意义了。可打印代码在系统中无法去掉。
第二、日志可以细分为多个级别,有的负责关键点的信息给开发者查看,有的打印当前变量的值,有的只是为记录操作,后期方便错过跟踪。

于是就诞生了日志系统,而Log4j是最成熟的一套之一。
它通过发明了日志级别。
Log4j建议只使用4个级别,从高到低分别为ERROR > WARN > INFO > DEBUG
而且级别是有层次的,debug级别照样会输出ERROR/WARN/INFO的信息,info级别信息就不会输出DEBUG,而会输出ERROR/WARN的,这个实际开发很有用,随着系统的使用,系统越来越稳定,系统的bug越来越少,debug就不需要,甚至最终只输出error就可以了。

这篇关于黑豹程序员-架构师学习路线图-百科:Log4j 业务日志代码分离的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/311909

相关文章

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁

精选20个好玩又实用的的Python实战项目(有图文代码)

《精选20个好玩又实用的的Python实战项目(有图文代码)》文章介绍了20个实用Python项目,涵盖游戏开发、工具应用、图像处理、机器学习等,使用Tkinter、PIL、OpenCV、Kivy等库... 目录① 猜字游戏② 闹钟③ 骰子模拟器④ 二维码⑤ 语言检测⑥ 加密和解密⑦ URL缩短⑧ 音乐播放

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

Python实现MQTT通信的示例代码

《Python实现MQTT通信的示例代码》本文主要介绍了Python实现MQTT通信的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 安装paho-mqtt库‌2. 搭建MQTT代理服务器(Broker)‌‌3. pytho

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java

使用Python构建一个高效的日志处理系统

《使用Python构建一个高效的日志处理系统》这篇文章主要为大家详细讲解了如何使用Python开发一个专业的日志分析工具,能够自动化处理、分析和可视化各类日志文件,大幅提升运维效率,需要的可以了解下... 目录环境准备工具功能概述完整代码实现代码深度解析1. 类设计与初始化2. 日志解析核心逻辑3. 文件处

C++ Log4cpp跨平台日志库的使用小结

《C++Log4cpp跨平台日志库的使用小结》Log4cpp是c++类库,本文详细介绍了C++日志库log4cpp的使用方法,及设置日志输出格式和优先级,具有一定的参考价值,感兴趣的可以了解一下... 目录一、介绍1. log4cpp的日志方式2.设置日志输出的格式3. 设置日志的输出优先级二、Window