flume啟動報錯:java.lang.NoSuchMethodError: com.google.common.base.Preconditions.checkArgument(ZLjava/lang/String;Ljava/lang/Object;)V


一、問題描述

  新部署的flume在啟動時候報錯:java.lang.NoSuchMethodError: com.google.common.base.Preconditions.checkArgument(ZLjava/lang/String;Ljava/lang/Object;)V


2020-06-30 11:40:20,359 (SinkRunner-PollingRunner-DefaultSinkProcessor) [ERROR - org.apache.flume.sink.hdfs.HDFSEventSink.process(HDFSEventSink.java:459)] process failed
java.lang.NoSuchMethodError: com.google.common.base.Preconditions.checkArgument(ZLjava/lang/String;Ljava/lang/Object;)V
  at org.apache.hadoop.conf.Configuration.set(Configuration.java:1357)
  at org.apache.hadoop.conf.Configuration.set(Configuration.java:1338)
  at org.apache.hadoop.conf.Configuration.setBoolean(Configuration.java:1679)
  at org.apache.flume.sink.hdfs.BucketWriter.open(BucketWriter.java:221)
  at org.apache.flume.sink.hdfs.BucketWriter.append(BucketWriter.java:572)
  at org.apache.flume.sink.hdfs.HDFSEventSink.process(HDFSEventSink.java:412)
  at org.apache.flume.sink.DefaultSinkProcessor.process(DefaultSinkProcessor.java:67)
  at org.apache.flume.SinkRunner$PollingRunner.run(SinkRunner.java:145)
  at java.lang.Thread.run(Thread.java:748)
Exception in thread "SinkRunner-PollingRunner-DefaultSinkProcessor" java.lang.NoSuchMethodError: com.google.common.base.Preconditions.checkArgument(ZLjava/lang/String;Ljava/lang/Object;)V
  at org.apache.hadoop.conf.Configuration.set(Configuration.java:1357)
  at org.apache.hadoop.conf.Configuration.set(Configuration.java:1338)
  at org.apache.hadoop.conf.Configuration.setBoolean(Configuration.java:1679)
  at org.apache.flume.sink.hdfs.BucketWriter.open(BucketWriter.java:221)
  at org.apache.flume.sink.hdfs.BucketWriter.append(BucketWriter.java:572)
  at org.apache.flume.sink.hdfs.HDFSEventSink.process(HDFSEventSink.java:412)
  at org.apache.flume.sink.DefaultSinkProcessor.process(DefaultSinkProcessor.java:67)
  at org.apache.flume.SinkRunner$PollingRunner.run(SinkRunner.java:145)

報錯截圖:

{F664C7E8-5A5F-4B93-8A03-B42B20BFEFF5}_20200630115354

問題解決:

一般這類問題,classNotFound,不是少jar包,那就是jar包沖突,查看flume安裝目錄下lib下面查看是有guava這個包的:

image

排除少包jar包的問題,那就是jar包沖突,在查看,本地環境hadoop目錄下lib中也是有這個guava這個包:

image

顯然是二者版本不一致導致的

問題解決:

找到原因之后,那就有解決辦法了

將原有的flume中的低版本的guava包移除,然后拷貝hadoop/lib目錄下的高版本的jar包到flume/lib中:

image

image

完成上述兩步操作之后,然后重新啟動flume,報錯消失


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM