log4j,slf4j (日志记录工具)

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: 一个logger对应着若干个appender和一个日志级别。 一个appender对应着一个输出位置与格式。 1.获取 <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.17</vers

一个logger对应着若干个appender和一个日志级别。

一个appender对应着一个输出位置与格式。

1.获取

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

需要的jar包、log4j.properties文件等项目结构见图1。


图1 log4j.properties文件的默认位置

也可以自己指定配置文件路径,见下;

void org.apache.log4j.PropertyConfigurator.configure(String configFilename)

2.日志格式

layout指定了布局与内容。常用的见下表:

Layout类名
作 用
org.apache.log4j.HTMLLayout
以HTML表格形式布局
org.apache.log4j.PatternLayout
可以灵活地指定布局模式
org.apache.log4j.SimpleLayout
包含日志信息的级别和信息字符串
org.apache.log4j.TTCCLayout
包含日志产生的时间、线程、类别等等信息
其中 PatternLayout最为灵活,它的一些格式占位符见下:

%c 输出日志信息所属的类的全名 
%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy-MM-dd HH:mm:ss },输出类似:2002-10-18- 22:10:28 
%f 输出日志信息所属的类的类名 
%l 输出日志事件的发生位置,即输出日志信息的语句处于它所在的类的第几行 
%m 输出代码中指定的信息,如log(message)中的message 
%n 输出一个回车换行符,Windows平台为“rn”,Unix平台为“n” 
%p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL。如果是调用debug()输出的,则为DEBUG,依此类推 
%r 输出自应用启动到输出该日志信息所耗费的毫秒数 
%t 输出产生该日志事件的线程名

如下行配置的显示效果见下下行;
log4j.appender.appender1.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} [%c]-[%p]-[%l] %m%n 

2015-08-03 10:52:23 [com.ctrip.search.antibot.esper.worker.RuleWorker]-[DEBUG]-[com.ctrip.search.antibot.esper.worker.RuleWorker.modifyAntibotEplTable(RuleWorker.java:54)] 日志具体内容

3.常用函数

void com.ctrip.search.logging.ESLogger.error(String msg, Object... params)

用于记录string。

void com.ctrip.search.logging.ESLogger.error(String msg,Throwablecause, Object... params)

我们catch(Exception e)到的异常都是Throwable类型的,若想打印错误栈信息,可将e放入此函数的第二个实参位置上,log4j就帮我们打印调用栈了。

比如logger.error(e,e),就等价于logger.error(e.toString(),e),就等价于logger.error(e.getMessage(),e);。

注意:若程序抛出了RuntimeException e,而我们没有try{}catch{ logger.error(e,e)},那么日志中就没有这个异常信息。所以启动脚本一般会这么写;

4.例子

log4j.properties文件内容见下:

#可以设置级别:debug>info>error
#debug:显示debug、info、error
#info:显示info、error
#error:只error
#log4j.rootLogger=debug,appender1
#输出到多个目的地
log4j.rootLogger=info,appender1,appender2
#log4j.rootLogger=error,appender1

#输出到控制台
log4j.appender.appender1=org.apache.log4j.ConsoleAppender
#样式为TTCCLayout
log4j.appender.appender1.layout=org.apache.log4j.TTCCLayout

#输出到文件,每天一个文件
log4j.appender.appender2=org.apache.log4j.DailyRollingFileAppender
#指定输出文件,${catalina.home}为tomcat启动时设置的变量,就是tomcat工作目录
log4j.appender.appender2.file=${catalina.home}/logs/qing-WebLog.log
#样式为TTCCLayout
log4j.appender.appender2.layout=org.apache.log4j.TTCCLayout
对应的效果见图2:

图2 与上面配置对应的输出内容
qing-WebLog.log是总记录。每过一天会把当天的单独写到带日期的文件里。

5.多个logger

多个logger更为灵活,可以记录特定的信息。比如自己的项目proA依赖了proB,proB里面有很多打日志的代码,干扰了我们proA的业务日志,那么就可以让它们使用不同的logger,记往不同的地方。
有两种做法——限定包名或指定logger名字。

5.1 指定logger名字

log4j.logger.myLogger=info,appender3
#若不加这一行,rootLogger同样会记载此logger的日志
log4j.additivity.myLogger=false
log4j.appender.appender3=org.apache.log4j.ConsoleAppender
log4j.appender.appender3.layout=org.apache.log4j.TTCCLayout
对应的java语句见下:
	static final Logger myLogger = LoggerFactory.getLogger("myLogger");

5.2 限定包名

如 log4j.logger. com.likeyichu.proa=info,myAppender
在java中正常用 Logger logger=Logger.getLogger(myClass.class);

6.自定义appender

例子见下。
#use own appender
log4j.rootLogger = INFO,YICHU
log4j.appender.YICHU = com.yichudu.logger.appender.YichuAppender
log4j.appender.YICHU.layout = org.apache.log4j.PatternLayout
log4j.appender.YICHU.layout.ConversionPattern = [%d{yyyy-MM-dd HH:mm:ss}][%p][%c]%m%n

7.指定配置文件

若不指定,则默认找classpath下的log4j.properties或log4j.xml。
在spring-web项目中,可用下面的配置。注意log4j初试在context前。
	<context-param>
	   <param-name>contextConfigLocation</param-name>
	   <param-value>classpath:service.xml</param-value>
	</context-param> 
	<context-param>
		<param-name>log4jConfigLocation</param-name>
		<param-value>/WEB-INF/log4j.xml</param-value>
	</context-param>
	
	<listener>
		<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
	</listener> 
	<listener>
		<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
	</listener>

8. slf4j

获取

<!--以与log4j搭配为例-->
<dependency>
	<groupId>org.slf4j</groupId>
	<artifactId>slf4j-log4j12</artifactId>
	<version>1.7.7</version>
</dependency>

slf4j,Simple Logging Facade for Java,用于java的简单日志门面系统。它不是具体的日志记录工具,类似于jdbc,提供了日志记录的统一接口。
使用哪种工具实现日志记录,不需要代码指定,只要将与你打算使用的日志系统对应的jar包加入到项目中,SLF4J就会自动选择使用你加入的那种日志系统。
slf4j中,使用下行语句得到logger:
Logger org.slf4j.LoggerFactory.getLogger(Class clazz)

相关实践学习
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
目录
相关文章
|
8月前
|
存储 Java 文件存储
微服务——SpringBoot使用归纳——Spring Boot使用slf4j进行日志记录—— logback.xml 配置文件解析
本文解析了 `logback.xml` 配置文件的详细内容,包括日志输出格式、存储路径、控制台输出及日志级别等关键配置。通过定义 `LOG_PATTERN` 和 `FILE_PATH`,设置日志格式与存储路径;利用 `&lt;appender&gt;` 节点配置控制台和文件输出,支持日志滚动策略(如文件大小限制和保存时长);最后通过 `&lt;logger&gt;` 和 `&lt;root&gt;` 定义日志级别与输出方式。此配置适用于精细化管理日志输出,满足不同场景需求。
2091 1
|
8月前
|
Java 微服务 Spring
微服务——SpringBoot使用归纳——Spring Boot使用slf4j进行日志记录——使用Logger在项目中打印日志
本文介绍了如何在项目中使用Logger打印日志。通过SLF4J和Logback,可设置不同日志级别(如DEBUG、INFO、WARN、ERROR)并支持占位符输出动态信息。示例代码展示了日志在控制器中的应用,说明了日志配置对问题排查的重要性。附课程源码下载链接供实践参考。
985 0
|
8月前
|
SQL Java 数据库连接
微服务——SpringBoot使用归纳——Spring Boot使用slf4j进行日志记录—— application.yml 中对日志的配置
在 Spring Boot 项目中,`application.yml` 文件用于配置日志。通过 `logging.config` 指定日志配置文件(如 `logback.xml`),实现日志详细设置。`logging.level` 可定义包的日志输出级别,例如将 `com.itcodai.course03.dao` 包设为 `trace` 级别,便于开发时查看 SQL 操作。日志级别从高到低为 ERROR、WARN、INFO、DEBUG,生产环境建议调整为较高级别以减少日志量。本课程采用 yml 格式,因其层次清晰,但需注意格式要求。
780 0
|
8月前
|
Java API 开发者
微服务——SpringBoot使用归纳——Spring Boot使用slf4j进行日志记录——slf4j 介绍
在软件开发中,`System.out.println()`常被用于打印信息,但大量使用会增加资源消耗。实际项目推荐使用slf4j结合logback输出日志,效率更高。Slf4j(Simple Logging Facade for Java)是一个日志门面,允许开发者通过统一方式记录日志,无需关心具体日志系统。它支持灵活切换日志实现(如log4j或logback),且具备简洁占位符和日志级别判断等优势。阿里巴巴《Java开发手册》强制要求使用slf4j,以保证日志处理方式的统一性和维护性。使用时只需通过`LoggerFactory`创建日志实例即可。
615 0
|
4月前
|
运维 安全 数据可视化
日志审查安排工具实战攻略:中小团队如何通过日志审查安排工具建立可控、安全的审查机制?
在审计敏感时代,日志审查安排工具成为安全运维与合规管理的关键利器。它实现审查任务的流程化、周期化与可视化,支持多系统协作、责任到人,确保“可控、可查、可追”的日志治理。工具如板栗看板、Asana、Monday 等提供任务调度、问题闭环与合规对接能力,助力企业构建高效、透明的日志审查体系,提升安全与合规水平。
|
5月前
|
JavaScript API 开发工具
HarmonyOS NEXT实战:日志工具
本文介绍了在HarmonyOS Next应用开发中,如何封装一个简单易用的日志工具LoggerKit。通过使用系统提供的HiLog API,开发者可以灵活输出不同级别的日志信息(DEBUG、INFO、WARN、ERROR、FATAL),用于分析应用运行状态和调试逻辑问题。文章详细说明了日志级别、参数配置及使用注意事项,并提供了完整的TypeScript封装示例代码,便于实际项目集成与应用调试。
136 0
|
8月前
|
监控 Java 应用服务中间件
Tomcat log日志解析
理解和解析Tomcat日志文件对于诊断和解决Web应用中的问题至关重要。通过分析 `catalina.out`、`localhost.log`、`localhost_access_log.*.txt`、`manager.log`和 `host-manager.log`等日志文件,可以快速定位和解决问题,确保Tomcat服务器的稳定运行。掌握这些日志解析技巧,可以显著提高运维和开发效率。
809 13
|
9月前
|
存储 缓存 关系型数据库
图解MySQL【日志】——Redo Log
Redo Log(重做日志)是数据库中用于记录数据页修改的物理日志,确保事务的持久性和一致性。其主要作用包括崩溃恢复、提高性能和保证事务一致性。Redo Log 通过先写日志的方式,在内存中缓存修改操作,并在适当时候刷入磁盘,减少随机写入带来的性能损耗。WAL(Write-Ahead Logging)技术的核心思想是先将修改操作记录到日志文件中,再择机写入磁盘,从而实现高效且安全的数据持久化。Redo Log 的持久化过程涉及 Redo Log Buffer 和不同刷盘时机的控制参数(如 `innodb_flush_log_at_trx_commit`),以平衡性能与数据安全性。
414 5
图解MySQL【日志】——Redo Log
|
8月前
|
SQL 存储 关系型数据库
简单聊聊MySQL的三大日志(Redo Log、Binlog和Undo Log)各有什么区别
在MySQL数据库管理中,理解Redo Log(重做日志)、Binlog(二进制日志)和Undo Log(回滚日志)至关重要。Redo Log确保数据持久性和崩溃恢复;Binlog用于主从复制和数据恢复,记录逻辑操作;Undo Log支持事务的原子性和隔离性,实现回滚与MVCC。三者协同工作,保障事务ACID特性。文章还详细解析了日志写入流程及可能的异常情况,帮助深入理解数据库日志机制。
1039 0
|
9月前
|
存储 关系型数据库 MySQL
图解MySQL【日志】——Undo Log
Undo Log(回滚日志)是 MySQL 中用于实现事务原子性和一致性的关键机制。在默认的自动提交模式下,MySQL 隐式开启事务,每条增删改语句都会记录到 Undo Log 中。其主要作用包括:
310 0