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

如何解决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");
    }
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?