首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >电子病历上的光束抛出一个java.util.ServiceConfigurationError

电子病历上的光束抛出一个java.util.ServiceConfigurationError
EN

Stack Overflow用户
提问于 2020-10-03 03:49:38
回答 1查看 325关注 0票数 0

我有一个Apache应用程序(使用Beam版本的EMR(emr-5.30.1) 2.23.0),我试图在预装Flink(1.10.0)的AWS 上部署它。

当我将应用程序部署到本地停靠flink集群上时,应用程序没有出现任何问题。但当我做的时候

代码语言:javascript
复制
flink run -m yarn-cluster -c my_class my_jar.jar

EMR集群的主节点

我得到了

代码语言:javascript
复制
java.util.ServiceConfigurationError: com.fasterxml.jackson.databind.Module: Provider com.fasterxml.jackson.module.jaxb.JaxbAnnotationModule not a subtype
at java.util.ServiceLoader.fail(ServiceLoader.java:239)
at java.util.ServiceLoader.access$300(ServiceLoader.java:185)
at java.util.ServiceLoader$LazyIterator.nextService(ServiceLoader.java:376)
at java.util.ServiceLoader$LazyIterator.next(ServiceLoader.java:404)
at java.util.ServiceLoader$1.next(ServiceLoader.java:480)
at com.fasterxml.jackson.databind.ObjectMapper.findModules(ObjectMapper.java:1054)
at org.apache.beam.sdk.options.PipelineOptionsFactory.<clinit>(PipelineOptionsFactory.java:471)
at org.myapp.main(MainApp.java:78)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.apache.flink.client.program.PackagedProgram.callMainMethod(PackagedProgram.java:321)
at org.apache.flink.client.program.PackagedProgram.invokeInteractiveModeForExecution(PackagedProgram.java:205)
at org.apache.flink.client.ClientUtils.executeProgram(ClientUtils.java:138)
at org.apache.flink.client.cli.CliFrontend.executeProgram(CliFrontend.java:664)
at org.apache.flink.client.cli.CliFrontend.run(CliFrontend.java:213)
at org.apache.flink.client.cli.CliFrontend.parseParameters(CliFrontend.java:895)
at org.apache.flink.client.cli.CliFrontend.lambda$main$10(CliFrontend.java:968)
at java.security.AccessController.doPrivileged(Native Method)
at javax.security.auth.Subject.doAs(Subject.java:422)
at org.apache.hadoop.security.UserGroupInformation.doAs(UserGroupInformation.java:1844)
at org.apache.flink.runtime.security.HadoopSecurityContext.runSecured(HadoopSecurityContext.java:41)
at org.apache.flink.client.cli.CliFrontend.main(CliFrontend.java:968)

问题似乎与org.apache.beam.sdk.options.PipelineOptionsFactory.<clinit>(PipelineOptionsFactory.java:471)有关,但我不清楚是什么导致了这种行为。

有人能告诉我是什么原因造成的吗?

提前谢谢你!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-03-12 07:56:58

这可能是类加载问题。

在EMR EC2实例中,已经有一些jars,这些库在您自己的依赖项之前加载。因此,运行时使用的版本是EMR提供的版本,而不是您在自己的pom.xml中作为依赖项提供的版本。

有多种解决方案:

在您的loading

  • whatever中,使用与EMR

  • 在EC2实例中提供的版本相同的版本,用

  • 替换EMR版本,更改库

  • 解决方案的顺序,您需要将所有必需的依赖项发送到Flink,而不仅仅是包含自己的代码

的jar。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64180509

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档