簡體   English   中英

java.lang.NoSuchFieldError:Eclipse中用於簡單hbase Java客戶端的IBM_JAVA

[英]java.lang.NoSuchFieldError: IBM_JAVA for a simple hbase java client in Eclipse

正如標題所示,我的源代碼是:

package hbase;

import java.io.IOException;

import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.HColumnDescriptor;
import org.apache.hadoop.hbase.HTableDescriptor;
import org.apache.hadoop.hbase.client.HBaseAdmin;
import org.apache.hadoop.hbase.util.Bytes;

public class HbaseExampleClient {
public static void main(String[] args) throws IOException {
    Configuration config = HBaseConfiguration.create();
    config.set("hbase.zookeeper.quorum", "192.168.10.17");
    config.set("hbase.zookeeper.property.clientPort", "2222");
    HBaseAdmin admin = new HBaseAdmin(config);//reports an IBM_JAVA NoSuchFieldError
    HTableDescriptor htd = new HTableDescriptor("test1111");
    HColumnDescriptor hcd = new HColumnDescriptor("data");
    htd.addFamily(hcd);
    admin.createTable(htd);
    byte[] tablename = htd.getName();
    HTableDescriptor[] tables = admin.listTables();
    if(tables.length!= 1 && Bytes.equals(tablename, tables[0].getName()))
    {
        throw new IOException("Failed create of table!");
    }
    admin.close();
}
}

Exception in thread "main" java.lang.NoSuchFieldError: IBM_JAVA
    at org.apache.hadoop.security.UserGroupInformation.getOSLoginModuleName(UserGroupInformation.java:337)
    at org.apache.hadoop.security.UserGroupInformation.<clinit>(UserGroupInformation.java:382)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    at java.lang.reflect.Method.invoke(Unknown Source)
    at org.apache.hadoop.hbase.util.Methods.call(Methods.java:37)
    at org.apache.hadoop.hbase.security.User.call(User.java:624)
    at org.apache.hadoop.hbase.security.User.callStatic(User.java:614)
    at org.apache.hadoop.hbase.security.User.access$300(User.java:52)
    at org.apache.hadoop.hbase.security.User$SecureHadoopUser.<init>(User.java:431)
    at org.apache.hadoop.hbase.security.User$SecureHadoopUser.<init>(User.java:426)
    at org.apache.hadoop.hbase.security.User.getCurrent(User.java:177)
    at org.apache.hadoop.hbase.client.UserProvider.getCurrent(UserProvider.java:78)
    at org.apache.hadoop.hbase.client.UserProvider.getCurrentUserName(UserProvider.java:62)
    at org.apache.hadoop.hbase.client.HConnectionManager$HConnectionKey.<init>(HConnectionManager.java:473)
    at org.apache.hadoop.hbase.client.HConnectionManager.getConnection(HConnectionManager.java:198)
    at org.apache.hadoop.hbase.client.HBaseAdmin.<init>(HBaseAdmin.java:116)
    at hbase.HbaseExampleClient.main(HbaseExampleClient.java:19)

似乎此錯誤與hbase服務器無關,因為我可以正確使用hbase shell。 但是我真的不知道如何解決這個問題。我的筆記本電腦(windows)Eclipse和遠程桌面(Ubuntu)linux Eclipse都報告了相同的錯誤。

有人可以幫助我嗎?

我也面臨着相同的問題,但是找到了解決方案,因為IBM_JAVA不變,所以由於jar問題而發生此問題

 public static final boolean IBM_JAVA = JAVA_VENDOR_NAME.contains("IBM");

並且此常量在org.apache.hadoop.util.PlatformName類中定義,但是此包結構和類在兩個jar中定義:

  1. Hadoop核心
  2. hadoop-auth

但是hadoop-core中存在的類沒有此常量。

IBM_JAVA

您的應用程序試圖在hadoop-core jar中進行搜索。 因此,在您的應用程序中添加hadoop-auth jar。

將早期版本的jars用於hadoop-corehadoop-auth時,我遇到了同樣的問題。 使用以下版本的jars解決了我的問題。

hadoop-core-1.2.1.jar

hadoop-auth-2.2.0.jar

我遇到了這樣的問題,並從hadoop-common-XXXjar刪除了fs (文件系統)和security 然后,將其兼容的源代碼添加到我的java源代碼中。 此外,我刪除了hadoop-auth 因為這是我的第一個測試,所以我刪除了它們以使我的代碼運行。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM