[HADOOP] java.lang.NoSuchFieldError : Eclipse에서 간단한 hbase Java 클라이언트 용 IBM_JAVA
HADOOPjava.lang.NoSuchFieldError : Eclipse에서 간단한 hbase Java 클라이언트 용 IBM_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.<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 서버와 아무런 관련이없는 것 같습니다. 하지만 난 정말이 문제를 해결하는 방법을 모르겠다. 둘 다 내 노트북 (Windows)에서 이클립스 및 원격 데스크톱 (우분투) 리눅스 이클립스 같은 오류를보고합니다.
누구든지 나를 도울 수 있습니까?
해결법
-
==============================
1.나는 또한 같은 문제에 직면했지만 솔루션을 발견, 이 문제점은 IBM_JAVA가 상수이기 때문에 jar 문제점으로 인해 발생합니다.
나는 또한 같은 문제에 직면했지만 솔루션을 발견, 이 문제점은 IBM_JAVA가 상수이기 때문에 jar 문제점으로 인해 발생합니다.
public static final boolean IBM_JAVA = JAVA_VENDOR_NAME.contains("IBM");
이 정수는 org.apache.hadoop.util.PlatformName 클래스로 정의되고 있습니다 만,이 패키지 구조와 클래스는 2 개의 jar로 정의되고 있습니다.
그러나 hadoop-core에있는 클래스에는이 상수가 없습니다.
그리고 애플리케이션이 hadoop-core jar에서 검색하려고합니다. 그래서 애플리케이션에 hadoop-auth jar를 추가하십시오.
-
==============================
2.이전 버전의 hadoop-core 및 hadoop-auth 용 jar를 사용할 때도 동일한 문제가 발생했습니다. 아래 버전 병을 사용하여 내 문제를 해결합니다.
이전 버전의 hadoop-core 및 hadoop-auth 용 jar를 사용할 때도 동일한 문제가 발생했습니다. 아래 버전 병을 사용하여 내 문제를 해결합니다.
-
==============================
3.나는 그런 문제를 안고 hadoop-common-X.X.X.jar에서 fs (파일 시스템)와 보안을 제거했다. 그런 다음 호환 가능한 소스 코드를 내 Java 소스 코드에 추가했습니다. 게다가 나는 hadoop-auth를 삭제했다. 그것은 첫 번째 테스트이기 때문에 코드를 제거하기 위해 제거했습니다.
나는 그런 문제를 안고 hadoop-common-X.X.X.jar에서 fs (파일 시스템)와 보안을 제거했다. 그런 다음 호환 가능한 소스 코드를 내 Java 소스 코드에 추가했습니다. 게다가 나는 hadoop-auth를 삭제했다. 그것은 첫 번째 테스트이기 때문에 코드를 제거하기 위해 제거했습니다.
from https://stackoverflow.com/questions/24105852/java-lang-nosuchfielderror-ibm-java-for-a-simple-hbase-java-client-in-eclipse by cc-by-sa and MIT license
'HADOOP' 카테고리의 다른 글
[HADOOP] 하이브 외부 테이블의 최대 열 수 (0) | 2019.06.26 |
---|---|
[HADOOP] Camus 마이그레이션 - Kafka HDFS Connect가 설정된 오프셋에서 시작하지 않습니다. (0) | 2019.06.26 |
[HADOOP] hbase와 hive의 차이점은 무엇입니까? (하둡) (0) | 2019.06.26 |
[HADOOP] sudo hadoop 대 su hadoop (0) | 2019.06.26 |
[HADOOP] 하이브 맵퍼 작업을 늘리지 못합니까? (0) | 2019.06.26 |