黑豹程序员-架构师学习路线图-百科: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

相关文章

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志

《SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志》在SpringBoot项目中,使用logback-spring.xml配置屏蔽特定路径的日志有两种常用方式,文中的... 目录方案一:基础配置(直接关闭目标路径日志)方案二:结合 Spring Profile 按环境屏蔽关

Java中Map.Entry()含义及方法使用代码

《Java中Map.Entry()含义及方法使用代码》:本文主要介绍Java中Map.Entry()含义及方法使用的相关资料,Map.Entry是Java中Map的静态内部接口,用于表示键值对,其... 目录前言 Map.Entry作用核心方法常见使用场景1. 遍历 Map 的所有键值对2. 直接修改 Ma

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

Golang 日志处理和正则处理的操作方法

《Golang日志处理和正则处理的操作方法》:本文主要介绍Golang日志处理和正则处理的操作方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录1、logx日志处理1.1、logx简介1.2、日志初始化与配置1.3、常用方法1.4、配合defer

深入解析 Java Future 类及代码示例

《深入解析JavaFuture类及代码示例》JavaFuture是java.util.concurrent包中用于表示异步计算结果的核心接口,下面给大家介绍JavaFuture类及实例代码,感兴... 目录一、Future 类概述二、核心工作机制代码示例执行流程2. 状态机模型3. 核心方法解析行为总结:三

python获取cmd环境变量值的实现代码

《python获取cmd环境变量值的实现代码》:本文主要介绍在Python中获取命令行(cmd)环境变量的值,可以使用标准库中的os模块,需要的朋友可以参考下... 前言全局说明在执行py过程中,总要使用到系统环境变量一、说明1.1 环境:Windows 11 家庭版 24H2 26100.4061

pandas实现数据concat拼接的示例代码

《pandas实现数据concat拼接的示例代码》pandas.concat用于合并DataFrame或Series,本文主要介绍了pandas实现数据concat拼接的示例代码,具有一定的参考价值,... 目录语法示例:使用pandas.concat合并数据默认的concat:参数axis=0,join=

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

C#代码实现解析WTGPS和BD数据

《C#代码实现解析WTGPS和BD数据》在现代的导航与定位应用中,准确解析GPS和北斗(BD)等卫星定位数据至关重要,本文将使用C#语言实现解析WTGPS和BD数据,需要的可以了解下... 目录一、代码结构概览1. 核心解析方法2. 位置信息解析3. 经纬度转换方法4. 日期和时间戳解析5. 辅助方法二、L