【发布时间】:2021-10-17 15:20:49
【问题描述】:
我无法通过将 logging.level 设置为 application.properties 中的包名称,让 Camel DSL 将 DEBUG 日志打印到 Spring Boot 下的控制台:
logging.level.org.test.logdemo=debug
如果我将 LoggingLevel 设置为 INFO 或 WARN,则会打印日志:
.when(simple("${exchangeProperty.xmltestresult} == ''"))
.log(LoggingLevel.INFO, "2nd choice ID was empty")
.log(LoggingLevel.WARN, "2nd choice ID was empty")
.log(LoggingLevel.DEBUG,"2nd choice ID was empty")
^ INFO 和 WARN 都打印,DEBUG 不打印。
如果我为路由指定一个名称,并在 application.properties 文件中引用它,则会打印 DEBUG 日志:
logging.level.FileRoute=debug
from("file:///home/user/xmlfilein").routeId("FileRoute")
...
.when(simple("${exchangeProperty.xmltestresult} == ''"))
.log(LoggingLevel.INFO,"2nd choice ID was empty")
.log(LoggingLevel.WARN,"2nd choice ID was empty")
.log(LoggingLevel.DEBUG,"2nd choice was empty")
^ 打印所有这些日志。
我刚刚开始使用 Camel Spring Boot,我使用 Spring Initializr 生成了项目,它提供了以下 pom.xml:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.5.3</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>org.test</groupId>
<artifactId>logdemo</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>logdemo</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>11</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.apache.camel.springboot</groupId>
<artifactId>camel-spring-boot-starter</artifactId>
<version>3.11.1</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
设置logging.level.root=debug 也能正常工作,并用调试消息淹没控制台,我试图避免这种情况:)
有没有其他人遇到过这种情况并提出解决方案?是否存在覆盖 package=debug 设置的更上/下链?
这是这个版本的 Camel/Spring Boot 的已知错误吗?迄今为止我读过的所有内容都表明这应该有效。
【问题讨论】:
-
阅读文档,查看在 Camel 路由中使用 log eip 时的默认日志名称是什么:camel.apache.org/components/latest/eips/… 您需要设置路由 id 或更改默认日志名称,如文档
-
谢谢克劳斯!我没有意识到我也必须这样做,我以为我只需要在 application.properties 中设置包名。
标签: spring-boot debugging logging apache-camel