本地依赖的 Quarkus ClassNotFoundException [重复]

Posted

技术标签:

【中文标题】本地依赖的 Quarkus ClassNotFoundException [重复]【英文标题】:Quarkus ClassNotFoundException for local dependency [duplicate] 【发布时间】:2020-08-02 03:00:43 【问题描述】:

我正在尝试将一个项目迁移到 Quarkus。该项目依赖于本地 .jar 文件。对于驻留在所述 jar 中的类,使用 Quarkus 运行应用程序会导致 java.lang.NoClassDefFoundError/java.lang.ClassNotFoundException

我使用 gradle 作为构建工具,本地 jar 文件作为依赖项添加使用:

implementation fileTree(dir: 'libs', include: ['*.jar'])

假设库包含某个类Foo 和一个静态方法init(),那么下面的代码会导致错误:

// From the local jar
import org.somepackage.Foo;

@Startup
@Singleton
public class Main 

  @PostConstruct
  public void initLocalLibrary() 
    Foo.init();
  


确切的输出是

2020-04-19 18:31:21,266 ERROR [io.qua.application] (main) Failed to start application: java.lang.NoClassDefFoundError: org/somepackage/Foo
    at Main.initLocalLibrary(Main.java:)
    at Main.initLocalLibrary_Bean.create(Main_Bean.zig:129)
    at Main_Bean.create(Main_Bean.zig:183)
Caused by: java.lang.ClassNotFoundException: org.somepackage.Foo

    at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(BuiltinClassLoader.java:581)
    at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(ClassLoaders.java:178)
    at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:521)
    at io.quarkus.bootstrap.classloading.QuarkusClassLoader.loadClass(QuarkusClassLoader.java:322)
    at io.quarkus.bootstrap.classloading.QuarkusClassLoader.loadClass(QuarkusClassLoader.java:275)
    at io.quarkus.bootstrap.classloading.QuarkusClassLoader.loadClass(QuarkusClassLoader.java:322)
    at io.quarkus.bootstrap.classloading.QuarkusClassLoader.loadClass(QuarkusClassLoader.java:275)
    ... 35 more

2020-04-19 18:31:21,302 ERROR [io.qua.dev.DevModeMain] (main) Failed to start Quarkus: java.lang.RuntimeException: Failed to start quarkus
    at io.quarkus.runner.ApplicationImpl.doStart(ApplicationImpl.zig:232)
    at io.quarkus.runtime.Application.start(Application.java:90)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.base/java.lang.reflect.Method.invoke(Method.java:566)
    at io.quarkus.runner.bootstrap.StartupActionImpl.run(StartupActionImpl.java:99)
    at io.quarkus.dev.IsolatedDevModeMain.firstStart(IsolatedDevModeMain.java:60)
    at io.quarkus.dev.IsolatedDevModeMain.accept(IsolatedDevModeMain.java:236)
    at io.quarkus.dev.IsolatedDevModeMain.accept(IsolatedDevModeMain.java:39)
    at io.quarkus.bootstrap.app.CuratedApplication.runInCl(CuratedApplication.java:131)
    at io.quarkus.bootstrap.app.CuratedApplication.runInAugmentClassLoader(CuratedApplication.java:84)
    at io.quarkus.dev.DevModeMain.start(DevModeMain.java:113)
    at io.quarkus.dev.DevModeMain.main(DevModeMain.java:54)

在没有 Quarkus 的情况下运行应用程序可以正常工作。

【问题讨论】:

【参考方案1】:

请尝试更换

implementation fileTree(dir: 'libs', include: ['*.jar'])

api fileTree(dir: 'libs', include: ['*.jar'])

【讨论】:

以上是关于本地依赖的 Quarkus ClassNotFoundException [重复]的主要内容,如果未能解决你的问题,请参考以下文章

quarkus依赖注入之十:学习和改变bean懒加载规则

quarkus依赖注入之八:装饰器(Decorator)

Quarkus 和提供的依赖项 (sapjco3.jar)

quarkus依赖注入之九:bean读写锁

quarkus依赖注入之十三:其他重要知识点大串讲(终篇)

quarkus依赖注入之十三:其他重要知识点大串讲(终篇)