java.lang.NoSuchFieldError:IBM_JAVA,用于Eclipse中的简单hbase Java客户端

标题是。我的源代码是:

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.(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.(User.java:431) at org.apache.hadoop.hbase.security.User$SecureHadoopUser.(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.(HConnectionManager.java:473) at org.apache.hadoop.hbase.client.HConnectionManager.getConnection(HConnectionManager.java:198) at org.apache.hadoop.hbase.client.HBaseAdmin.(HBaseAdmin.java:116) at hbase.HbaseExampleClient.main(HbaseExampleClient.java:19) 

似乎这个错误与hbase服务器无关,因为我可以正确使用hbase shell。 但我真的不知道如何解决这个问题。从我的笔记本电脑(Windows)Eclipse和远程桌面(Ubuntu)linux Eclipse报告相同的错误。

有人可以帮帮我吗?

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

  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。

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

Hadoop的核心1.2.1.jar

Hadoop的AUTH-2.2.0.jar

我有这样的问题,并从hadoop-common-XXXjar删除了fs (文件系统)和security 。 然后我将其兼容的源代码添加到我的java源代码中。 除此之外我删除了hadoop-auth 。 因为这是我的第一次测试,我删除它们以使我的代码运行。