У меня есть простое приложение, использующее платформу Quarkus версии 3.6.1.
package net.example.dashboard.dbcli;
import org.slf4j.*;
import io.quarkus.runtime.Startup;
import jakarta.annotation.PostConstruct;
import jakarta.enterprise.context.ApplicationScoped;
@Startup
@ApplicationScoped
public class Main {
final Logger logger = LoggerFactory.getLogger(Main.class);
@PostConstruct
public void init() {
System.out.println("App started");
logger.error("Logger says hello");
}
}
Если я запускаю встроенное приложение в JVM, оно, как ожидается, работает: я вижу текст, выведенный на консоль, и я вижу отображаемые выходные данные моего журнала, а также некоторые выходные данные журнала из платформы. сам по себе.
$ java -jar target/quarkus-app/quarkus-run.jar
App started
2024-02-04 18:21:15,701 ERROR [net.exa.das.dbc.Main] (main) Logger says hello
2024-02-04 18:21:15,715 INFO [io.quarkus] (main) dbcli 1.0.0 on JVM (powered by Quarkus 3.6.1) started in 0.768s.
2024-02-04 18:21:15,719 INFO [io.quarkus] (main) Profile prod activated.
2024-02-04 18:21:15,719 INFO [io.quarkus] (main) Installed features: [cdi]
Однако, когда я запускаю собственный образ приложения, я вижу сообщения о том, что поставщик SLF4J не найден, и не вижу результатов своего журнала.
$ target/dbcli
SLF4J: No SLF4J providers were found.
SLF4J: Defaulting to no-operation (NOP) logger implementation
SLF4J: See https://www.slf4j.org/codes.html#noProviders for further details.
App started
2024-02-04 18:17:41,741 INFO [io.quarkus] (main) dbcli 1.0.0 native (powered by Quarkus 3.6.1) started in 0.030s.
2024-02-04 18:17:41,741 INFO [io.quarkus] (main) Profile prod activated.
2024-02-04 18:17:41,741 INFO [io.quarkus] (main) Installed features: [cdi]
похоже, что приложение использовало SLF4Jv1, но поставщиком является SLF4Jv2, хотя я не могу это доказать.
Кто-нибудь сталкивался с этим раньше или может подсказать, как лучше понять, что происходит?
Моя платформа:
OS: Oracle Linux 8
Java: OpenJDK 21.0.2+13-LTS
GraalVM: Mandrel-23.1.2.0-Final (runs in container)
Podman 4.0.2 (rootless)
pom.xml:
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"
xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
4.0.0
net.example.dashboard
dbcli
1.0.0
3.8.1
true
21
21
UTF-8
UTF-8
3.6.1
quarkus-bom
io.quarkus.platform
3.6.1
dbcli
false
native
false
INFO
true
${quarkus.platform.group-id}
${quarkus.platform.artifact-id}
${quarkus.platform.version}
pom
import
io.quarkus
quarkus-arc
io.quarkus
quarkus-maven-plugin
${quarkus-plugin.version}
build
maven-compiler-plugin
${compiler-plugin.version}
21
org.jboss.jandex
jandex-maven-plugin
1.2.3
make-index
jandex
Также опубликовано здесь: Чат пользователей Quarkus Development
Добавление дерева зависимостей maven:
[INFO] --- dependency:3.6.0:tree (default-cli) @ dbcli ---
[INFO] net.example.dashboard:dbcli:jar:1.0.0
[INFO] \- io.quarkus:quarkus-arc:jar:3.6.1:compile
[INFO] +- io.quarkus.arc:arc:jar:3.6.1:compile
[INFO] | +- jakarta.enterprise:jakarta.enterprise.cdi-api:jar:4.0.1:compile
[INFO] | | +- jakarta.enterprise:jakarta.enterprise.lang-model:jar:4.0.1:compile
[INFO] | | +- jakarta.el:jakarta.el-api:jar:5.0.1:compile
[INFO] | | \- jakarta.interceptor:jakarta.interceptor-api:jar:2.1.0:compile
[INFO] | +- jakarta.annotation:jakarta.annotation-api:jar:2.1.1:compile
[INFO] | +- jakarta.transaction:jakarta.transaction-api:jar:2.0.1:compile
[INFO] | +- io.smallrye.reactive:mutiny:jar:2.5.1:compile
[INFO] | | \- io.smallrye.common:smallrye-common-annotation:jar:2.1.2:compile
[INFO] | \- org.jboss.logging:jboss-logging:jar:3.5.3.Final:compile
[INFO] +- io.quarkus:quarkus-core:jar:3.6.1:compile
[INFO] | +- jakarta.inject:jakarta.inject-api:jar:2.0.1:compile
[INFO] | +- io.smallrye.common:smallrye-common-os:jar:2.1.2:compile
[INFO] | +- io.quarkus:quarkus-ide-launcher:jar:3.6.1:compile
[INFO] | +- io.quarkus:quarkus-development-mode-spi:jar:3.6.1:compile
[INFO] | +- io.smallrye.config:smallrye-config:jar:3.4.4:compile
[INFO] | | \- io.smallrye.config:smallrye-config-core:jar:3.4.4:compile
[INFO] | | +- org.eclipse.microprofile.config:microprofile-config-api:jar:3.0.3:compile
[INFO] | | +- io.smallrye.common:smallrye-common-classloader:jar:2.1.2:compile
[INFO] | | \- io.smallrye.config:smallrye-config-common:jar:3.4.4:compile
[INFO] | +- org.jboss.logmanager:jboss-logmanager:jar:3.0.2.Final:compile
[INFO] | | +- io.smallrye.common:smallrye-common-constraint:jar:2.1.2:compile
[INFO] | | +- io.smallrye.common:smallrye-common-cpu:jar:2.1.2:compile
[INFO] | | +- io.smallrye.common:smallrye-common-expression:jar:2.1.2:compile
[INFO] | | | \- io.smallrye.common:smallrye-common-function:jar:2.1.2:compile
[INFO] | | +- io.smallrye.common:smallrye-common-net:jar:2.1.2:compile
[INFO] | | +- io.smallrye.common:smallrye-common-ref:jar:2.1.2:compile
[INFO] | | +- jakarta.json:jakarta.json-api:jar:2.1.3:compile
[INFO] | | \- org.eclipse.parsson:parsson:jar:1.1.5:compile
[INFO] | +- org.jboss.logging:jboss-logging-annotations:jar:2.2.1.Final:compile
[INFO] | +- org.jboss.threads:jboss-threads:jar:3.5.1.Final:compile
[INFO] | +- org.slf4j:slf4j-api:jar:2.0.6:compile
[INFO] | +- org.jboss.slf4j:slf4j-jboss-logmanager:jar:2.0.0.Final:compile
[INFO] | +- org.wildfly.common:wildfly-common:jar:1.7.0.Final:compile
[INFO] | +- io.quarkus:quarkus-bootstrap-runner:jar:3.6.1:compile
[INFO] | | +- io.smallrye.common:smallrye-common-io:jar:2.1.2:compile
[INFO] | | \- io.github.crac:org-crac:jar:0.1.3:compile
[INFO] | \- io.quarkus:quarkus-fs-util:jar:0.0.9:compile
[INFO] \- org.eclipse.microprofile.context-propagation:microprofile-context-propagation-api:jar:1.3:compile
Подробнее здесь: https://stackoverflow.com/questions/779 ... native-app
При запуске сообщения с помощью собственного приложения Quarkus поставщики SLF4J не были найдены. ⇐ JAVA
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение