При использовании DataFlowJavaOperator вам необходимо следовать инструкциям о том, как создать файл ".jar":
- Добавить зависимость и плагинпо ссылке
- Запустите
mvn package
, чтобы создать файл ".jar"
Как только вы это сделаете, я бы посоветовал убедиться, что файл ".jar" действительно запущенправильно, прежде чем пытаться запустить его внутри Composer.Таким образом, в этом случае , следуя инструкции , запустите:
java -jar target/BeamTutorial-0.0.1-SNAPSHOT.jar --runner=DataflowRunner --p
roject=<my-project> --tempLocation=<my-bucket>
Я также получу:
Error: A JNI error has occurred, please check your installation and try again
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/beam/sdk/options/PipelineOptions
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.options.PipelineOptions
at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:338)
at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
... 7 more
Так что проблема выглядит более связанной с Java и как pomнастроен, что не создает действительный файл .jar, или он ожидает некоторых дополнительных параметров.В любом случае вам следует устранить неполадки с «.jar» / pom, прежде чем идти дальше.
Для некоторых других конвейеров, которые у меня есть, я успешно их запустил, используя DataflowJavaOperator и действительный файл «.jar».