1

正如标题所说。我的源代码是:

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 server无关,因为我可以正确使用hbase shell。但我真的不知道如何解决这个问题。我的笔记本电脑(windows)Eclipse 和远程桌面(Ubuntu)linux Eclipse 都报告了同样的错误。

任何人都可以帮助我吗?

4

3 回答 3

7

我也面临同样的问题,但找到了解决方案,这个问题是由于 jar 问题而发生的,因为 IBM_JAVA 是恒定的

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

并且此常量在类 org.apache.hadoop.util.PlatformName 中定义,但此包结构和类在两个 jar 中定义:

  1. hadoop 核心
  2. hadoop-身份验证

但是 hadoop-core 中的类没有这个常量。

IBM_JAVA

并且您的应用程序试图在 hadoop-core jar 中进行搜索。因此,在您的应用程序中添加 hadoop-auth jar。

于 2014-08-13T16:49:35.417 回答
1

在为hadoop-corehadoop-auth使用早期版本的 jar 时,我遇到了同样的问题。使用以下版本的 jar 解决了我的问题。

hadoop-core-1.2.1.jar

hadoop-auth-2.2.0.jar

于 2016-06-22T17:22:51.620 回答
0

我遇到了这样的问题,fssecurityhadoop-common-X.X.X.jar. 然后我将其兼容的源代码添加到我的 java 源代码中。此外我删除了hadoop-auth. 因为这是我的第一次测试,所以我删除了它们以使我的代码运行。

于 2017-03-01T12:48:28.107 回答