java.lang.NoSuchMethodError: org.apache.commons.cli.CommandLine.hasOption(Lorg/apache/commons/cli/Op

flink 版本:1.15.2

flink-yarn application 模式启动的任务提交成功,正常运行。

想要测试下保存点,以及停止任务和启动任务。

flink 命令执行时,报错如下:(flink  stop 时也是一样的错)

[hadoop@cdh02 bin]$ ./flink savepoint 5a9c9e94312e87f445d6dd98b225294a hdfs://nameservice1/flink/checkpoints -yid application_1686560568214_0018
SLF4J: Class path contains multiple SLF4J bindings.
SLF4J: Found binding in [jar:file:/data/install/flink-1.15.2/lib/log4j-slf4j-impl-2.17.1.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Found binding in [jar:file:/opt/cloudera/parcels/CDH-6.3.2-1.cdh6.3.2.p0.1605554/jars/slf4j-log4j12-1.7.25.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation.
SLF4J: Actual binding is of type [org.apache.logging.slf4j.Log4jLoggerFactory]
java.lang.NoSuchMethodError: org.apache.commons.cli.CommandLine.hasOption(Lorg/apache/commons/cli/Option;)Z
    at org.apache.flink.client.cli.SavepointOptions.<init>(SavepointOptions.java:45)
    at org.apache.flink.client.cli.CliFrontend.savepoint(CliFrontend.java:724)
    at org.apache.flink.client.cli.CliFrontend.parseAndRun(CliFrontend.java:1096)
    at org.apache.flink.client.cli.CliFrontend.lambda$main$10(CliFrontend.java:1156)
    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:1898)
    at org.apache.flink.runtime.security.contexts.HadoopSecurityContext.runSecured(HadoopSecurityContext.java:41)
    at org.apache.flink.client.cli.CliFrontend.main(CliFrontend.java:1156)
 

乍一看,jar包不存在,那可能就是有冲突或者不存在。但是在之前放过 commons-cli-1.4.jar 的jar包在 flink 的 lib目录下,是存在的。那有可能就是冲突或者版本不对了。然后拉下1.15.2的源码,查看依赖的commons-cli的版本是几。源码解压缩,查看pom,1.5.0

 

 版本不匹配啊,用的低了,找个1.5.0 的替换之前的1.4.0的。maven仓库有时候进不去,下面找的是其他仓库的,很快。毕竟也不大,几十K的包。

Central Repository: commons-cli/commons-cli/1.5.0

上传替换后,再执行,就OK了。问题解决,供此类问题参考。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
java.lang.NoSuchMethodError: org.apache.commons.lang3.reflect.MethodUtils.ge。 这个错误通常发生在Java程序中,表示代码中调用的方法在所使用的库中不存在。具体来说,这个错误的原因是程序代码中使用了Apache Commons Lang库中的MethodUtils类的ge方法,但是实际的库中并没有这个方法。在这种情况下,Java虚拟机会抛出NoSuchMethodError异常,告知调用者该方法不存在。 要解决这个问题,我们可以考虑以下几个步骤: 1. 确认所使用的Apache Commons Lang库版本是否正确。可能是因为你使用的是一个过时的版本,其中并没有ge方法。可以通过查看官方文档或者Apache Commons Lang库的源代码来确认版本。 2. 检查代码中对MethodUtils.ge方法的调用。确认是否拼写错误、错误参数、错误的方法签名等导致方法找不到。 3. 如果确认版本和代码调用都正确,那可能是因为你使用的Apache Commons Lang版本与其他依赖库存在冲突。这种情况下,可能需要升级或者降级Apache Commons Lang库的版本,以解决冲突。 4. 如果以上步骤都没有解决问题,考虑尝试替换使用其他类似的方法,或者寻找其他解决方案来完成代码中原本需要使用MethodUtils.ge方法的操作。 总之,NoSuchMethodError异常是因为在程序代码中调用的方法在所使用的库中不存在。通过检查所使用的库版本、代码中的调用以及可能存在的依赖库冲突,可以解决这个问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值