log4j 的使用和配置简介

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: 12345log4jlog4j1.2.17级别OFF 关闭所有日志记录FATAL 严重的错误事件将会导致应用程序的退出ERROR 虽然发生错误事件,但仍然不影响系统的继续运行。

1
2
3
4
5

<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>

级别
OFF 关闭所有日志记录
FATAL 严重的错误事件将会导致应用程序的退出
ERROR 虽然发生错误事件,但仍然不影响系统的继续运行。
WARN 会出现潜在错误的情形。
INFO 消息在粗粒度级别上突出强调应用程序的运行过程。
DEBUG 指出细粒度信息事件对调试应用程序是非常有帮助的
ALL 开启所有的日志记录

级别优先级
OFF > FATAL > ERROR > WARN > INFO > DEBUG > ALL
使用
在pom.xml 中添加依赖
在项目的中添加log4j.properties

配置
log4.rootLogger
log4j.rootLogger=日志级别,appender1, appender2, ….
注意,rootLogger默认是对整个工程生效
注意,如果只想对某些包操作,那么:log4j.logger.com.hutu=info, stdout,表示该日志对package com.hutu生效
注意,这样做可以区分dev/线上,也可以减小性能影响:if(log.isDebugEnabled()){log.debug();}

基础配置
Appender
属性
描述

layout
Appender 使用 Layout 对象和与之关联的模式来格式化日志信息。

target
目的地可以是控制台、文件,或依赖于 appender 的对象

level
级别用来控制过滤日志信息

threshold
Appender 可脱离于日志级别定义一个阀值级别,Appender 对象会忽略所有级别 低于阀值级别的日志。

filter
Filter 对象可在级别基础之上分析日志信息,来决定 Appender 对象是否处理或忽 略一条日志记录。

所有appender
官方文档

AppenderSkeleton
AsyncAppender
ConsoleAppender
输出到控制台
1
2
3
4
5
6
7

log4j.rootLogger = debug , stdout , D , E

输出到控制台

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 = %d{ABSOLUTE} %5p %c{ 1 }:%L - %m%n

DailyRollingFileAppender
每天产生一个文件
ExternallyRolledFileAppender
FileAppender
文件
JDBCAppender
将日志信息保存到数据库中
JMSAppender
LF5Appender
NTEventLogAppender
NullAppender
RollingFileAppender
文件大小到达指定大小,则新创建个文件
SMTPAppender
SocketAppender
SocketHubAppender
SyslogAppender
TenetAppender
WriterAppender
将日志信息以流格式发送到任意指定的地方
Layout
Layouts
DateLayout
HTMLLayout
PatternLayout
SimpleLayout
XMLLayout
日志格式化
模式转换符
转换字符
含义

c
使用它为输出日志分类,比如对于分类”a.b.c”,模式%c{2}会输出”b.c”

C
使用它输出发起记录日志请求的类的全名。比如对于类”cn.fondme.logger.XXClass”,模式%C{1}会输出”XXClass”

d
使用它输出记录日志的日期,比如%d{HH:mm:ss}

F
在记录日志时,使用它输出文件名

I
用它输出生成日志的调用者的地域信息。

L
使用它输出发起日志请求的行号。

m
使用它输出和日志事件关联的,由应用提供的信息。

M
使用它输出发起日志请求的方法名。

n
输出平台相关的换行符。

p
输出日志事件的优先级。

r
使用它输出从构建布局到生成日志事件所花费的时间,以毫秒为单位。

t
输出生成日志事件的线程名。

x
输出和生成日志事件线程相关的 NDC (嵌套诊断上下文)。

X
该字符后跟 MDC 键,比如 X{clientIP} 会输出保存在 MDC 中键 clientIP 对应的值。

%
百分号, %% 会输出一个 %。

格式修饰符
格式修饰符
左对齐
最小宽度
最大宽度
注释

%20c

20

如果列名少于 20 个字符,左边使用空格补齐

%-20c

20

如果列名少于 20 个字符,右边使用空格补齐。

%.30c
不适用

30
如果列名长于 30 个字符,从开头剪除。

%20.30c

20
30
如果列名少于 20 个字符,左边使用空格补齐,如果列名长于 30 个字 符,从开头剪除。

%-20.30c

20
30
如果列名少于 20 个字符,右边使用空格补齐,如果列名长于 30 个字 符,从开头剪除。

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
3天前
|
XML 安全 Java
【日志框架整合】Slf4j、Log4j、Log4j2、Logback配置模板
本文介绍了Java日志框架的基本概念和使用方法,重点讨论了SLF4J、Log4j、Logback和Log4j2之间的关系及其性能对比。SLF4J作为一个日志抽象层,允许开发者使用统一的日志接口,而Log4j、Logback和Log4j2则是具体的日志实现框架。Log4j2在性能上优于Logback,推荐在新项目中使用。文章还详细说明了如何在Spring Boot项目中配置Log4j2和Logback,以及如何使用Lombok简化日志记录。最后,提供了一些日志配置的最佳实践,包括滚动日志、统一日志格式和提高日志性能的方法。
78 30
【日志框架整合】Slf4j、Log4j、Log4j2、Logback配置模板
|
1月前
|
网络协议 Linux Windows
Rsyslog配置不同端口收集不同设备日志
Rsyslog配置不同端口收集不同设备日志
|
1月前
|
开发工具 git
git显示开发日志+WinSW——将.exe文件注册为服务的一个工具+图床PicGo+kubeconfig 多个集群配置 如何切换
git显示开发日志+WinSW——将.exe文件注册为服务的一个工具+图床PicGo+kubeconfig 多个集群配置 如何切换
35 1
|
1月前
|
数据采集 监控 Java
SpringBoot日志全方位超详细手把手教程,零基础可学习 日志如何配置及SLF4J的使用......
本文是关于SpringBoot日志的详细教程,涵盖日志的定义、用途、SLF4J框架的使用、日志级别、持久化、文件分割及格式配置等内容。
93 0
SpringBoot日志全方位超详细手把手教程,零基础可学习 日志如何配置及SLF4J的使用......
|
3月前
|
Java 应用服务中间件 HSF
Java应用结构规范问题之配置Logback以仅记录错误级别的日志到一个滚动文件中的问题如何解决
Java应用结构规范问题之配置Logback以仅记录错误级别的日志到一个滚动文件中的问题如何解决
|
3月前
|
Java 应用服务中间件 HSF
Java应用结构规范问题之配置Logback以在控制台输出日志的问题如何解决
Java应用结构规范问题之配置Logback以在控制台输出日志的问题如何解决
|
3月前
|
存储 Ubuntu Apache
如何在 Ubuntu VPS 上配置 Apache 的日志记录和日志轮转
如何在 Ubuntu VPS 上配置 Apache 的日志记录和日志轮转
46 6
|
3月前
|
存储 Ubuntu 应用服务中间件
如何在 Ubuntu VPS 上配置 Nginx 的日志记录和日志轮转
如何在 Ubuntu VPS 上配置 Nginx 的日志记录和日志轮转
32 4
|
3月前
|
存储 容器
【Azure 事件中心】为应用程序网关(Application Gateway with WAF) 配置诊断日志,发送到事件中心
【Azure 事件中心】为应用程序网关(Application Gateway with WAF) 配置诊断日志,发送到事件中心
|
3月前
|
人工智能
【Azure Application Insights】在Azure Function中启用Application Insights后,如何配置不输出某些日志到AI 的Trace中
【Azure Application Insights】在Azure Function中启用Application Insights后,如何配置不输出某些日志到AI 的Trace中