数据流和稳定依赖性冲突



我遇到的错误:

Error: A JNI error has occurred, please check your installation and try again
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/beam/sdk/transforms/DoFn
    at java.lang.Class.getDeclaredMethods0(Native Method)
    at java.lang.Class.privateGetDeclaredMethods(Class.java:2701)
    at java.lang.Class.privateGetMethodRecursive(Class.java:3048)
    at java.lang.Class.getMethod0(Class.java:3018)
    at java.lang.Class.getMethod(Class.java:1784)
    at sun.launcher.LauncherHelper.validateMainClass(LauncherHelper.java:544)
    at sun.launcher.LauncherHelper.checkAndLoadMain(LauncherHelper.java:526)
Caused by: java.lang.ClassNotFoundException: org.apache.beam.sdk.transforms.DoFn
    at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:335)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
    ... 7 more

我的pom依赖性:

<dependencies>
        <dependency>
            <groupId>com.google.cloud.bigtable</groupId>
            <artifactId>bigtable-hbase-beam</artifactId>
            <version>1.11.0</version>
        </dependency>
        <dependency>
            <groupId>org.apache.beam</groupId>
            <artifactId>beam-runners-google-cloud-dataflow-java</artifactId>
            <version>2.13.0</version>
            <scope>runtime</scope>
        </dependency>
    </dependencies>

我认为该问题来自使用Beam SDK的不同版本的两个依赖项,因此我将beam-runners-google-cloud-dataflow-java版本更改为2.11.0,该版本使用了相同的Beam SDK版本。但是我有同样的错误。

任何帮助将不胜感激!

您如何运行管道?我猜想问题是梁罐不在您的类路径上。您要么需要使用Maven Exec插件来调用您的Main((与Class Path上的所有Maven依赖关系,要么需要使用Maven Shade插件或Maven Assembly插件来创建一个胖罐。请参阅此处,例如如何使用Maven Exec插件运行管道:https://github.com/googlecloudplatform/cloud-bigtable-examples/blob/a017a237a237fa8dae7644451a658158158158158158190743C1B41B4127/

最新更新