logback系列之一:输出日志到控制台
logback系列之二:输出日志到文件
logback系列之三:输出日志到文件(滚动)
logback系列之四:输出日志到不同文件
和
logback系列之一:输出日志到控制台类似,改动的地方:
1. logback[-test].xml文件:
<appender name="fileAppender" class="ch.qos.logback.core.FileAppender">
<file>/logs/granularity.log</file>
<encoder><!-- 必须指定,否则不会往文件输出内容 -->
<pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{5} - %msg%n</pattern>
</encoder>
<append>true</append>
<prudent>false</prudent>
</appender>
<root level="DEBUG">
<appender-ref ref="fileAppender" />
</root>
调用测试类的方法,生成granularity.log文件。
附:
①. prudent:小心的,慎重的。如果设置为true,不同JVM的file appenders能够安全地将日志输出到同一个文件中。
这是通过锁定文件通道实现的:
protected void writeOut(E event) throws IOException {
if (prudent) {
safeWrite(event);
} else {
super.writeOut(event);
}
}
private void safeWrite(E event) throws IOException {
ResilientFileOutputStream resilientFOS = (ResilientFileOutputStream) getOutputStream();
FileChannel fileChannel = resilientFOS.getChannel();
if (fileChannel == null) {
return;
}
FileLock fileLock = null;
try {
fileLock = fileChannel.lock(); // 加锁
long position = fileChannel.position();
long size = fileChannel.size();
if (size != position) {
fileChannel.position(size);
}
super.writeOut(event);
} finally {
if (fileLock != null) {
fileLock.release(); // 释放锁
}
}
}
②. 当prudent为true时,如果append设置为false,会被强行转成true。
这是在start方法中处理的:
if (prudent) {
if (!isAppend()) {
setAppend(true);
addWarn("Setting \"Append\" property to true on account of \"Prudent\" mode");
}
}
分享到:
相关推荐
Spring Boot 使用 Logback 输出日志文件 Spring Boot 提供了多种日志记录工具,包括 Logback、Log4J2 和 Java Util Logging。默认情况下,Spring Boot 使用 Logback 作为日志记录工具。在日志记录过程中,我们可以...
1. **无需读取日志文件**:传统方式下,日志通常被写入到磁盘文件中,然后由其他进程读取分析。这种方式存在延迟,并且可能导致大量磁盘I/O。通过WebSocket,日志可以直接从应用程序发送到前端,省去了读取文件的...
* `<appender name="ERROR" class="ch.qos.logback.core.rolling.RollingFileAppender">`:定义了出错日志appender,用于将错误日志输出到日志文件中。 * `<rollingPolicy class="ch.qos.logback.core.rolling....
标题"扩展logback将日志输出到Kafka实例源码"涉及的技术点主要集中在如何将Logback与Kafka集成,使得日志可以被有效地发送到Kafka集群。这个过程通常涉及到以下几个步骤: 1. **添加依赖**:首先,你需要在项目的...
总结起来,通过合理的Logback配置,我们可以实现日志的分类存储,提高日志输出的性能,并有效管理日志文件。这不仅有利于日常的开发调试,也能在系统出现问题时提供宝贵的线索,帮助我们快速定位和解决问题。
在 Logback 中,还有其他的 Layout 实现,例如 HTMLLayout、JSONLayout 等,可以根据需要选择合适的 Layout 实现来输出日志。 Logback 提供了强大的日志输出功能,通过配置文件和 Layout 实现,可以轻松地控制日志...
Logback提供了按日期滚动、按大小滚动等多种日志文件滚动策略,确保日志不会无限增长占用磁盘空间。 7. **MDC(Mapped Diagnostic Context)** MDC是Logback提供的一种特性,允许我们在代码中存储一些诊断信息,...
标题中的“扩展logback将日志输出到Kafka实例扩展源码”指的是在Java应用程序中,使用logback作为日志框架,并通过自定义appender(输出模块)将日志信息发送到Apache Kafka的消息队列中。Logback是SLF4J(Simple ...
配置文件可以指定日志级别(DEBUG, INFO, WARN, ERROR 等)、Appender(控制日志输出到哪里,如控制台、文件、数据库等)、Layout(日志的输出格式),以及过滤器等。例如,你可以设置 `root` logger 的级别,定义一...
Logback支持更复杂的配置,如文件输出、日志滚动、异步日志记录、过滤器和自定义编码器等。例如,可以配置一个将日志写入文件的Appender: ```xml <appender name="FILE" class="ch.qos.logback.core....
springboot 日志配置文件 logback 它当前分为以下三个模块: logback-core:其它两个模块的基础模块。 logback-classic:它是log4j的一个改良版本,同时它完整实现了slf4j API使你可以很方便地更换成其它日志系统如...
学习 Logback 包括理解如何配置 `logback.xml` 文件以满足项目需求,如何在代码中使用 SLF4J API 来记录日志,以及如何管理和优化日志输出,比如控制日志文件大小、滚动策略等。对于 Java 开发者来说,熟练掌握 ...
appender:指定日志输出的媒介,即输出地(可以是控制台,可以是文件,远程套接字服务器等); layout:用来格式化日志信息的输出。 二.logback优于log4的原因 Logback对log4j进行了大量改进,Logback就是更好的log...
目前所有的日志记录方式采用的都是同步的方式,即直接将日志写入文件。每次日志输出到文件都会...采用异步写日志的方式,通过不让主线程去写日志文件而减少磁盘IO,避免并发下造成线程阻塞,从而减少不必要的性能损耗。
- **大小滚动策略(SizeBasedTriggeringPolicy)**:当日志文件达到一定大小时,会自动创建新的日志文件并保留旧文件。 - **时间滚动策略(TimeBasedTriggeringPolicy)**:根据时间(如每天、每小时)滚动日志...
在`logback.xml`配置文件中,你可以通过以下方式设定日志级别: ```xml <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"> <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} -...
Logback 配置文件的灵活性使得它能够满足各种日志需求,包括控制日志级别、定制日志格式、设置日志输出位置以及管理日志文件大小。SLF4J 的使用则简化了与日志框架的交互,提供了良好的可移植性。正确配置和使用 ...
该配置使日志先按日期进行归类,然后按大小输出异步日志
这是logback的配置文件,用于定义日志的输出行为。在SpringBoot项目中,这个文件会被自动加载。在这个配置文件中,我们需要配置刚刚提到的`LogDBAppender`,通过`<appender>`标签进行声明,并设置相应的属性,如日志...
本文将详细介绍如何利用logback优化SpringBoot应用中的异常堆栈输出,以提高日志的可读性和实用性。 一、背景 在编程过程中,异常的抛出是难以避免的。为了便于调试和问题追踪,我们会记录异常堆栈信息。然而,原始...