logging.properties 文件的存在会阻止写入日志

问题描述

我有一个需要在 SLF4J 后面使用 Java Util Logging 的 Spring Boot Web 应用程序。当我不创建 logging.properties 文件时,控制台记录器工作得很好,并且记录了所有 INFO 消息及以上。当我创建一个 logging.properties 文件时,只记录了 FATAL 错误logging.properties 文件包含什么并不重要 - 我已经尝试了很多不同的配置 - 它只在该文件存在时记录致命错误

这是我导入的罐子(使用 Gradle)

    implementation("org.slf4j:slf4j-api")
    implementation("org.slf4j:slf4j-jdk14")

我还必须确保没有导入 logback-classic,因为我的一个依赖项试图将其引入。

configurations.all {
    exclude(group = "ch.qos.logback",module = "logback-classic")
}

那么,这是我的 logging.properties 文件。它位于 src/main/resources/logging.properties

handlers = java.util.logging.ConsoleHandler
.level= ALL
java.util.logging.ConsoleHandler.level = FInesT
java.util.logging.ConsoleHandler.formatter = java.util.logging.SimpleFormatter

这不是我尝试使用的唯一配置。

谁能发现我做错了什么?为什么它只记录 FATAL 错误

解决方法

您的 java.util.logging.config.file 系统属性是否指向可读文件?

import java.util.logging.*;
import java.io.File;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Paths;
import java.util.*;

public class Test {

    public static void main(String[] args) throws IOException {
        String file = System.getProperty("java.util.logging.config.file");
        if (file == null) {
            System.out.println("Configuration was not specified");
            return;
        }
        
        System.out.println(file);
        System.out.println(new File(file).getCanonicalPath());
        System.out.println(Files.isReadable(Paths.get(file)));
        System.out.println(Arrays.toString(Logger.getLogger("").getHandlers()));
    }
}

如果我运行这个测试程序指向一个不存在的文件,我会得到以下信息:

/home/jmehrens/logging.properties
/home/jmehrens/logging.properties
false
[]

输出中的 false 显示我在配置中指定的文件不可读(因为它在该位置不存在)。根记录器处理程序为空,因为日志管理器无法读取我的 logging.properties。

从终端您可以看到该文件不存在于该路径:

[jmehrens@localhost ~]$ pwd
/home/jmehrens
[jmehrens@localhost ~]$ ls logging.properties
ls: cannot access logging.properties: No such file or directory

您可以在相关答案中关注其他 debugging tips

您的脚本告诉我“未指定配置”。在使用 Gradle 构建 SpringBoot 应用程序的上下文中,我应该在哪里指定它?

Can I define System Properties within Spring Boot configuration files? 介绍了在 Spring Boot 中设置系统属性。 How to give System property to my test via Gradle and -D 介绍了如何通过 Gradle 传递属性。

如果这对您不起作用,那么您需要指定一个 PostConstruct 方法来定位日志配置文件和 configures the LogManager

,

我刚刚从 JUL 切换到 Log4j2,因为我更了解文档。

,

这对我来说适用于您现有的 logging.properties 文件。

我认为问题在于 java.util.logging 不查找属性资源,只是查找文件(或默认资源)。

我无法解释为什么当存在 logging.properties 资源时您会看到不同的行为。

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.io.IOException;
import java.io.InputStream;
import java.util.logging.LogManager;

public class Example2 {
    public static void main(String... args) throws IOException {
        final InputStream inputStream = Example2.class.getResourceAsStream("/logging.properties");
        LogManager.getLogManager().readConfiguration(inputStream);
        Logger logger = LoggerFactory.getLogger(Example2.class);
        logger.debug("message 0");
        logger.info("message 1");
        logger.error("message 2");
    }
}

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...