如何解决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 举报,一经查实,本站将立刻删除。