Я установил hadoop 2.5.2 и hbase 1.0.1.1 (которые совместимы друг с другом). Но в коде hadoop я пытаюсь добавить columnfamily в таблицу hbase.NoSuchMethodError HTableDescriptor.addFamily
Мой код
Configuration hbaseConfiguration = HBaseConfiguration.create();
Job hbaseImportJob = new Job(hbaseConfiguration, "FileToHBase");
HBaseAdmin hbaseAdmin = new HBaseAdmin(hbaseConfiguration);
if (!hbaseAdmin.tableExists(Config_values.tableName)) {
TableName tableName1 = TableName.valueOf("tableName");
HTableDescriptor hTableDescriptor = new HTableDescriptor(tableName1);
HColumnDescriptor hColumnDescriptor1 = new HColumnDescriptor("columnFamily1");
hTableDescriptor.addFamily(hColumnDescriptor1);
hbaseAdmin.createTable(hTableDescriptor);
}
Я получаю эту ошибку
java.lang.NoSuchMethodError: Exception in thread "main" java.lang.NoSuchMethodError: org.apache.hadoop.hbase.HTableDescriptor.addFamily(Lorg/apache/hadoop/hbase/HColumnDescriptor;)V at com.atm_ex.atm_ex.Profiles.profiles(Profiles.java:177) at com.atm_ex.atm_ex.App.main(App.java:28) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:606) at org.apache.hadoop.util.RunJar.main(RunJar.java:212)
Я бегу мой Hadoop код, используя HADOOP_CLASSPATH = '$ {HBASE_HOME}/bin/HBase целевых classpath' $ HADOOP_HOME/бен/Hadoop банку/Prog-1,0-SNAPSHOT.jar –