日志框架 --- Log4j

news/2024/9/19 8:05:09/

文章目录

  • 1. 什么是log4j
  • 2. log4j的日志级别
  • 3. 日志层级
  • 4. log4j使用实例
    • 4.1 添加log4j依赖
    • 4.2 添加配置文件
    • 4.3 编写代码
    • 4.4 测试代码
    • 4.5 运行结果
  • 5. 配置文件
    • 5.1 Logger 日志记录器
    • 5.2 Appender 附加器
    • 5.3 Layout 日志格式化器
  • 6. 整体演示
    • 6.1 配置文件
    • 6.2 运行结果

1. 什么是log4j

log4j是一个流行的Java日志框架,是由 Apache 的一个开源项目。它允许开发人员通过将日志语句插入应用程序代码中来记录应用程序运行时的事件。它能够控制通过哪些目标输出的消息以及每个目标的格式。

log4j主要是由 Logger,Appender,Layout 组成,
Logger,日志记录器,控制日志的输出级别以及是否输出日志。
Appender,控制日志被写入的位置,例如控制台、文件等。
Layout,用于定义日志输出的格式。

2. log4j的日志级别

Log4j有六个日志级别,分别是:TRACEDEBUGINFOWARNERRORFATAL
日志优先级为:TRACE<DEBUG<INFO<WARN<ERROR<FATAL

3. 日志层级

这里的日志层级和logback一样,根都是root,如果创建com.example.test, 根就是root,然后是com,再是example,最后就是test。这里的日志级别如果没有指定,也会继承父类。
在这里插入图片描述

4. log4j使用实例

4.1 添加log4j依赖

        <!-- https://mvnrepository.com/artifact/log4j/log4j --><dependency><groupId>log4j</groupId><artifactId>log4j</artifactId><version>1.2.17</version></dependency>

4.2 添加配置文件

在src/main/resources目录下,创建log4j.properties文件,编写下面代码。

log4j.rootLogger=DEBUG, stdoutlog4j.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=%d{ABSOLUTE} %5p %c{1}:%L - %m%n

4.3 编写代码


import org.apache.log4j.Logger;
import org.springframework.stereotype.Service;public class Log4jTest {private static final Logger logger = Logger.getLogger(Log4jTest.class);public void test() {logger.trace("===TRACE===");logger.debug("===DEBUG===");logger.info("===INFO===");logger.warn("===WARN===");logger.error("===ERROR===");logger.fatal("===FATAL===");}
}

4.4 测试代码


@SpringBootTest
class Log4jApplicationTests {@Resourceprivate Log4jTest log4jTest;@Testvoid test() {log4jTest.test();}}

4.5 运行结果

在这里插入图片描述

5. 配置文件

5.1 Logger 日志记录器

一般会设置根路径的日志级别使用 rootLogger 设置。也可以指定需要的包或者类设置一个 Logger。
使用示例:

# 定义根logger级别
log4j.rootLogger=DEBUG, stdout
# 定义指定路径logger级别
log4j.logger.com.example.log4j.test.Log4jTest=INFO, CONSOLE

5.2 Appender 附加器

appender用来控制日志信息输出的位置,部分可选项如下表格。

选项作用
ConsoleAppender将日志信息输出到控制台上
FileAppender将日志信息输出到文件中
RollingFileAppender基于文件大小或日期滚动生成新的日志文件,并将日志输出到这些文件中。
SocketAppender将日志信息输出到远程服务器的Socket端口
DBAppender将日志信息写入数据库中

使用示例:

# 定义名为CONSOLE的appender(输出到控制台)
log4j.appender.console=org.apache.log4j.ConsoleAppender# 定义名为file的appender(输出到文件中)
log4j.appender.file=org.apache.log4j.FileAppender
log4j.appender.file.File=E:/workspace/logfile.txt
log4j.appender.file.encoding=UTF-8# 定义名为rollingfile的appender(滚动的输出到文件中)
log4j.appender.rollingfile=org.apache.log4j.RollingFileAppender
log4j.appender.rollingfile.File=E:/workspace/logrollingfile.txt
log4j.appender.rollingfile.encoding=UTF-8
log4j.appender.file.MaxFileSize=10MB
log4j.appender.file.MaxBackupIndex=10

5.3 Layout 日志格式化器

用于控制输出日志的格式,和logback的pattern类似。

选项作用
SimpleLayout简单布局,输出包括级别和消息。
PatternLayout模式布局,允许你定义自己的输出格式,通过使用占位符指定输出内容的相对位置。
HTMLLayoutHTML布局,以HTML格式输出日志消息。
XMLLayoutXML布局,以XML格式输出日志消息。
TTCCLayout时间、线程、类别和内容布局,输出包括时间戳、线程名、日志器名称和消息。
EnhancedPatternLayout增强模式布局,与PatternLayout类似,但支持更多的占位符。

使用示例:

# 自定义输出格式
log4j.appender.console.layout=org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern=%d{HH:mm:ss.SSS} - %m%n# HTML布局
log4j.appender.file.layout=org.apache.log4j.HTMLLayout# 简单布局
log4j.appender.stdout.layout=org.apache.log4j.SimpleLayout

一些自定义输出格式

样式作用
%m输出代码中指定的日志信息
%p输出优先级,及 DEBUG、INFO 等
%n换行符
%r输出自应用启动到输出该 log 信息耗费的毫秒数
%c输出打印语句所属的类的全名
%t输出产生该日志的线程全名
%d输出服务器当前时间,默认格式为 ISO8601,也可以在后面指定格式。如:%d{yyyy年MM月dd日 HH:mm:ss}
%l输出日志时间发生的位置,包括类名、发生的线程,以及在代码中的行数,如:Test.main(Test.java:10)
%F输出日志消息产生时所在的文件名称
%L输出代码中的行号

6. 整体演示

6.1 配置文件

# 定义根logger级别
log4j.rootLogger=DEBUG, stdout
# 定义指定路径logger级别
log4j.logger.com.example.log4j.test.Log4jTest=INFO, console , file, rollingfile, stdout
# 设置不向上级传递
log4j.additivity.com.example.log4j.test.Log4jTest=false # 定义名为CONSOLE的appender(输出到控制台)
log4j.appender.console=org.apache.log4j.ConsoleAppender
log4j.appender.console.layout=org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern=%d{HH:mm:ss.SSS} - %m%n# 定义名为file的appender(输出到文件中)
log4j.appender.file=org.apache.log4j.FileAppender
log4j.appender.file.File=E:/workspace/logfile.html
log4j.appender.file.encoding=UTF-8
log4j.appender.file.layout=org.apache.log4j.HTMLLayout# 定义名为rollingfile的appender(滚动的输出到文件中)
log4j.appender.rollingfile=org.apache.log4j.RollingFileAppender
log4j.appender.rollingfile.File=E:/workspace/logrollingfile.html
log4j.appender.rollingfile.encoding=UTF-8
log4j.appender.rollingfile.MaxFileSize=10MB
log4j.appender.rollingfile.MaxBackupIndex=10
log4j.appender.rollingfile.layout=org.apache.log4j.HTMLLayout# 定义名为stdout的appender(输出到控制台)
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.SimpleLayout

6.2 运行结果

带有时间的就是自定义的输出格式,另一种就是简单布局的格式。

在这里插入图片描述

这是生成的两个日志文件

在这里插入图片描述

这是文件中的内容
在这里插入图片描述


http://www.ppmy.cn/news/217395.html

相关文章

git基础教程(18)git stash暂存本地修改

文章目录 git stash pushgit stash listgit stash popgit stash applygit stash showgit stash drop 序号git stash cleargit stash pop冲突解决git stash 命令是 Git 中一个非常实用的命令,它可以让开发者暂时存储当前工作区的内容而不必提交代码或创建新分支,得到一个干净的…

【计算机组成原理·笔记】主存储器概述

主存储器概述 主存与CPU的联系 主存和 MDR 通过数据总线通信CPU 向主存发出读/写指令MAR 通过地址总线向主存发送读写的目标地址 主存存储单元地址分配 存储单元的位置由单元地址号表示&#xff0c;具体要看机器的存储字长和寻址方式 例&#xff1a;某机器的字长为32位&am…

android版本占有率 umeng,友盟报告:国内安卓手机品牌前十名中9个是国产

【TechWeb报道】12月17日消息&#xff0c;友盟发布的报告显示&#xff0c;Android手机阵营中&#xff0c;国产品牌的市场占比进一步加大。在国内排名前十的安卓手机品牌中&#xff0c;仅有三星一家外资品牌&#xff0c;其余均为国产品牌产品。 友盟报告&#xff1a;国内安卓手机…

MySQL中的三种常见的排名

三种常见的排名 row_number、dense_rank、rank在MySQL 5.7中的实现 文章目录 三种常见的排名准备数据表结构说明创建SC表插入数据 ROW_NUMBERDENSE_RANKRANKROW_NUMBERDENSE_RANKRANK 准备数据 表结构说明 成绩表 SC(SId,CId,score) SId 学⽣编号 CId 课程编号 score 分数 …

手机耗电排名公布,第一名太意外了!

我们最亲近的&#xff0c;那莫过于手机了。除了洗澡睡觉&#xff0c;几乎所有时间我们都深度捆绑在一起 和手机关系密切的后果就是经常担心手机没电&#xff0c;也就是人们常说的“电量焦虑”。 现在手机电池的容量差不多已经饱和了&#xff0c;基本在 4000- 5000 毫安左右。 …

各种手机处理器排行榜_手机处理器CPU性能排名

0三星 Nexus S5427Android 2.3Hummingbird S5PC1101.44 GHz 超频 44%PowerVR SGX540 1三星 Facinate4427Android 2.3Hummingbird S5PC1101.40 GHz 超频 40%PowerVR SGX540 2三星 Nexus S4253Android 2.3Hummingbird S5PC1101.50 GHz 超频 50%PowerVR SGX540 3三星 Nexus S4098A…

手机什么处理器最好排名2021

那么当下手机处理器排名如何呢&#xff1f;又有哪些手机值得选择呢&#xff1f;一句话来说就是&#xff1a;苹果“超神”&#xff0c;高通第二&#xff0c;华为最高第四。我用的手机就是活动时7.5折抢购的 机会不容错过http://www.adiannao.cn/7 苹果超神 我们经常说苹果的iPho…

日撸java_day37

第 37 天: 十字链表 package datastructures.graph;/*** ClassName: OrthogonalList* Package: datastructures.graph* Description: Orthogonal List for directed graph.** Author: luv_x_c* Create: 2023/5/28 14:53*/ public class OrthogonalList {/*** An inner class f…

动态权限大全

1.android.permission.WRITE_USER_DICTIONARY 允许应用程序向用户词典中写入新词2.android.permission.WRITE_SYNC_SETTINGS 写入Google在线同步设置3.android.permission.WRITE_SOCIAL_STREAM 读取用户的社交信息流4.android.permission.WRITE_SMS 允许程序写短信5.android.pe…

FontAwesome图标大全

FontAwesome图标大全 FontAwesome图标大全 FontAwesome 4.7.0 图标大全&#xff0c;共计675个图标&#xff0c;以及其在图标字体中的Unicode编码cheatsheet列表&#xff0c;非常方便再WEB等开发过程中速查&#xff0c;一键复制&#xff0c;方便快捷。 https://tooltt.com/info…

支持蓝牙5.0手机大全

近两年发布的手机大都已取消3.5mm耳机孔&#xff0c;又由于没有线束缚&#xff0c;蓝牙耳机就这样一夜之间风靡开来。虽然都是蓝牙&#xff0c;但是各家耳机和手机采用的蓝牙技术却各不相同&#xff0c;比如现在很多耳机和手机就已经开始支持蓝牙5.0 了。那么蓝牙5.0 有什么好处…

qq里面cap字符_特殊符号大全

昵称专用特效字符: ︻︼︽︾〒↑↓☉⊙●〇◎★☆■▓「」『』◆◇▲△▼▽◣◥◢◣◤ ◥№↑↓→←↘↙Ψ※㊣∑⌒∩【】〖〗@ξζω□∮〓※》∏卐√ ╳々♀♂∞①ㄨ≡╬╭╮╰╯╱╲ ▂ ▂ ▃ ▄ ▅ ▆ ▇ █ ▂▃▅▆█ ▁▂▃▄▅▆▇█▇▆▅▄▃▂▁ 基础各类贴图符号…

GM命令代码大全

2871129715 1565079105 3154918763 3213860268 3013579557 3334928235 2535351329 /sro 唤醒 物品第一格子 /sro 1 511 2 511 77 511 说明一下77表示的杀死加伤害511 表示加伤害511 唤醒最多加511 1 表示加力量 2 表示加敏捷 3 表示加智力 4 表示加体力 9 表…

2022蓝牙耳机哪款更值得买?最受欢迎的十大蓝牙耳机排行榜

对于一个爱研究蓝牙耳机的学生党来说&#xff0c;蓝牙耳机在我生活中不可缺少。蓝牙耳机的便携程度极高&#xff0c;音质与有线耳机几乎无差&#xff0c;在生活中的便携使用让我越用越爱。听歌、追剧、打游戏&#xff0c;避免尴尬的同时还能带来极致的声音体验&#xff0c;声临…

通讯协议大全

目录 一、物理层、数据链路层协议 1、远距离蜂窝通信 &#xff08;1&#xff09;2G/3G/4G通信协议 &#xff08;2&#xff09;NB-IoT &#xff08;3&#xff09;5G 2、远距离非蜂窝通信 &#xff08;1&#xff09;WiFi &#xff08;2&#xff09;ZigBee &#xff08;3…

android 权限大全

访问登记属性 android.permission.ACCESS_CHECKIN_PROPERTIES &#xff0c;读取或写入登记check-in数据库属性表的权限 获取错略位置 android.permission.ACCESS_COARSE_LOCATION&#xff0c;通过WiFi或移动基站的方式获取用户错略的经纬度信息&#xff0c;定位精度大概误差在3…

大麦盒子(domybox)无法进入系统解决方案!【简单几步】

大麦盒子&#xff08;domybox&#xff09;无法进入系统解决方案&#xff01;【简单几步】 参考文章&#xff1a; &#xff08;1&#xff09;大麦盒子&#xff08;domybox&#xff09;无法进入系统解决方案&#xff01;【简单几步】 &#xff08;2&#xff09;https://www.cnb…

大麦自动抢票

直接来干货&#xff0c;需要准备工具&#xff1a;chrome&#xff0c;Tampermonkey。 第一步提前找到你要看到的演唱会&#xff0c;确定好日期、座次以及登陆时默认的收货信息&#xff1a; 第二部确认订单&#xff1a; 以上仅展示一部分&#xff0c;亲测有效哦。

大麦链接 大麦购票链接万能模版

后台更新了大麦链接 大麦万能模版

大麦盒子无线服务器连接超时,大麦盒子游戏联网失败怎么办

大麦盒子游戏联网失败怎么办&#xff1f;最近有很多玩家都对此有所疑问&#xff0c;今天安致小编为大家带来了大麦盒子游戏联网失败解决方法&#xff0c;感兴趣的玩家赶紧来安致网看看吧。 大麦盒子游戏联网失败解决方法 1、路由器正常工作的&#xff0c;但是搜索不到无线信号&…