HBASE-8361 Bulk load and other utilities should not create tables for user (Ashish Singhi)
Conflicts: hbase-server/src/test/java/org/apache/hadoop/hbase/mapreduce/TestLoadIncrementalHFiles.java
This commit is contained in:
parent
e0085d85ae
commit
a33c78872a
|
@ -39,6 +39,7 @@ import org.apache.hadoop.hbase.HColumnDescriptor;
|
|||
import org.apache.hadoop.hbase.HConstants;
|
||||
import org.apache.hadoop.hbase.HTableDescriptor;
|
||||
import org.apache.hadoop.hbase.TableName;
|
||||
import org.apache.hadoop.hbase.TableNotFoundException;
|
||||
import org.apache.hadoop.hbase.client.Admin;
|
||||
import org.apache.hadoop.hbase.client.HBaseAdmin;
|
||||
import org.apache.hadoop.hbase.client.HTable;
|
||||
|
@ -94,6 +95,7 @@ public class ImportTsv extends Configured implements Tool {
|
|||
final static String DEFAULT_ATTRIBUTES_SEPERATOR = "=>";
|
||||
final static String DEFAULT_MULTIPLE_ATTRIBUTES_SEPERATOR = ",";
|
||||
final static Class DEFAULT_MAPPER = TsvImporterMapper.class;
|
||||
public final static String CREATE_TABLE_CONF_KEY = "create.table";
|
||||
|
||||
public static class TsvParser {
|
||||
/**
|
||||
|
@ -432,10 +434,16 @@ public class ImportTsv extends Configured implements Tool {
|
|||
|
||||
if (hfileOutPath != null) {
|
||||
if (!admin.tableExists(tableName)) {
|
||||
LOG.warn(format("Table '%s' does not exist.", tableName));
|
||||
// TODO: this is backwards. Instead of depending on the existence of a table,
|
||||
// create a sane splits file for HFileOutputFormat based on data sampling.
|
||||
createTable(admin, tableName, columns);
|
||||
String errorMsg = format("Table '%s' does not exist.", tableName);
|
||||
if ("yes".equalsIgnoreCase(conf.get(CREATE_TABLE_CONF_KEY, "yes"))) {
|
||||
LOG.warn(errorMsg);
|
||||
// TODO: this is backwards. Instead of depending on the existence of a table,
|
||||
// create a sane splits file for HFileOutputFormat based on data sampling.
|
||||
createTable(admin, tableName, columns);
|
||||
} else {
|
||||
LOG.error(errorMsg);
|
||||
throw new TableNotFoundException(errorMsg);
|
||||
}
|
||||
}
|
||||
HTable table = new HTable(conf, tableName);
|
||||
job.setReducerClass(PutSortReducer.class);
|
||||
|
@ -534,6 +542,9 @@ public class ImportTsv extends Configured implements Tool {
|
|||
" -D" + MAPPER_CONF_KEY + "=my.Mapper - A user-defined Mapper to use instead of " +
|
||||
DEFAULT_MAPPER.getName() + "\n" +
|
||||
" -D" + JOB_NAME_CONF_KEY + "=jobName - use the specified mapreduce job name for the import\n" +
|
||||
" -D" + CREATE_TABLE_CONF_KEY + "=no - can be used to avoid creation of table by this tool\n" +
|
||||
" Note: if you set this to 'no', then the target table must already exist in HBase\n" +
|
||||
"\n" +
|
||||
"For performance consider the following options:\n" +
|
||||
" -Dmapreduce.map.speculative=false\n" +
|
||||
" -Dmapreduce.reduce.speculative=false";
|
||||
|
|
|
@ -18,6 +18,8 @@
|
|||
*/
|
||||
package org.apache.hadoop.hbase.mapreduce;
|
||||
|
||||
import static java.lang.String.format;
|
||||
|
||||
import java.io.FileNotFoundException;
|
||||
import java.io.IOException;
|
||||
import java.io.InterruptedIOException;
|
||||
|
@ -114,6 +116,7 @@ public class LoadIncrementalHFiles extends Configured implements Tool {
|
|||
public static final String MAX_FILES_PER_REGION_PER_FAMILY
|
||||
= "hbase.mapreduce.bulkload.max.hfiles.perRegion.perFamily";
|
||||
private static final String ASSIGN_SEQ_IDS = "hbase.mapreduce.bulkload.assign.sequenceNumbers";
|
||||
public final static String CREATE_TABLE_CONF_KEY = "create.table";
|
||||
|
||||
private int maxFilesPerRegionPerFamily;
|
||||
private boolean assignSeqIds;
|
||||
|
@ -148,9 +151,10 @@ public class LoadIncrementalHFiles extends Configured implements Tool {
|
|||
}
|
||||
|
||||
private void usage() {
|
||||
System.err.println("usage: " + NAME +
|
||||
" /path/to/hfileoutputformat-output " +
|
||||
"tablename");
|
||||
System.err.println("usage: " + NAME + " /path/to/hfileoutputformat-output tablename" + "\n -D"
|
||||
+ CREATE_TABLE_CONF_KEY + "=no - can be used to avoid creation of table by this tool\n"
|
||||
+ " Note: if you set this to 'no', then the target table must already exist in HBase\n"
|
||||
+ "\n");
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -906,7 +910,15 @@ public class LoadIncrementalHFiles extends Configured implements Tool {
|
|||
TableName tableName = TableName.valueOf(args[1]);
|
||||
|
||||
boolean tableExists = this.doesTableExist(tableName);
|
||||
if (!tableExists) this.createTable(tableName,dirPath);
|
||||
if (!tableExists) {
|
||||
if ("yes".equalsIgnoreCase(getConf().get(CREATE_TABLE_CONF_KEY, "yes"))) {
|
||||
this.createTable(tableName, dirPath);
|
||||
} else {
|
||||
String errorMsg = format("Table '%s' does not exist.", tableName);
|
||||
LOG.error(errorMsg);
|
||||
throw new TableNotFoundException(errorMsg);
|
||||
}
|
||||
}
|
||||
|
||||
Path hfofDir = new Path(dirPath);
|
||||
HTable table = new HTable(getConf(), tableName);
|
||||
|
|
|
@ -43,6 +43,7 @@ import org.apache.hadoop.hbase.HBaseTestingUtility;
|
|||
import org.apache.hadoop.hbase.HConstants;
|
||||
import org.apache.hadoop.hbase.LargeTests;
|
||||
import org.apache.hadoop.hbase.TableName;
|
||||
import org.apache.hadoop.hbase.TableNotFoundException;
|
||||
import org.apache.hadoop.hbase.client.HTable;
|
||||
import org.apache.hadoop.hbase.client.Result;
|
||||
import org.apache.hadoop.hbase.client.ResultScanner;
|
||||
|
@ -228,7 +229,20 @@ public class TestImportTsv implements Configurable {
|
|||
String data = "KEY\u001bVALUE4\u001bVALUE8\n";
|
||||
doMROnTableTest(util, FAMILY, data, args, 4);
|
||||
}
|
||||
|
||||
|
||||
@Test(expected = TableNotFoundException.class)
|
||||
public void testWithoutAnExistingTableAndCreateTableSetToNo() throws Exception {
|
||||
String table = "test-" + UUID.randomUUID();
|
||||
String[] args =
|
||||
new String[] { table, "/inputFile" };
|
||||
|
||||
Configuration conf = new Configuration(util.getConfiguration());
|
||||
conf.set(ImportTsv.COLUMNS_CONF_KEY, "HBASE_ROW_KEY,FAM:A");
|
||||
conf.set(ImportTsv.BULK_OUTPUT_CONF_KEY, "/output");
|
||||
conf.set(ImportTsv.CREATE_TABLE_CONF_KEY, "no");
|
||||
ImportTsv.createSubmittableJob(conf, args);
|
||||
}
|
||||
|
||||
protected static Tool doMROnTableTest(HBaseTestingUtility util, String family,
|
||||
String data, String[] args) throws Exception {
|
||||
return doMROnTableTest(util, family, data, args, 1);
|
||||
|
|
|
@ -33,6 +33,7 @@ import org.apache.hadoop.hbase.HBaseTestingUtility;
|
|||
import org.apache.hadoop.hbase.HColumnDescriptor;
|
||||
import org.apache.hadoop.hbase.HTableDescriptor;
|
||||
import org.apache.hadoop.hbase.LargeTests;
|
||||
import org.apache.hadoop.hbase.TableNotFoundException;
|
||||
import org.apache.hadoop.hbase.NamespaceDescriptor;
|
||||
import org.apache.hadoop.hbase.TableName;
|
||||
import org.apache.hadoop.hbase.client.HTable;
|
||||
|
@ -127,7 +128,7 @@ public class TestLoadIncrementalHFiles {
|
|||
new byte[][]{ Bytes.toBytes("fff"), Bytes.toBytes("zzz") },
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Test loading into a column family that has a ROWCOL bloom filter.
|
||||
*/
|
||||
|
@ -340,7 +341,7 @@ public class TestLoadIncrementalHFiles {
|
|||
map.put(last, value-1);
|
||||
}
|
||||
|
||||
@Test
|
||||
@Test
|
||||
public void testInferBoundaries() {
|
||||
TreeMap<byte[], Integer> map = new TreeMap<byte[], Integer>(Bytes.BYTES_COMPARATOR);
|
||||
|
||||
|
@ -350,8 +351,8 @@ public class TestLoadIncrementalHFiles {
|
|||
*
|
||||
* Should be inferred as:
|
||||
* a-----------------k m-------------q r--------------t u---------x
|
||||
*
|
||||
* The output should be (m,r,u)
|
||||
*
|
||||
* The output should be (m,r,u)
|
||||
*/
|
||||
|
||||
String first;
|
||||
|
@ -359,7 +360,7 @@ public class TestLoadIncrementalHFiles {
|
|||
|
||||
first = "a"; last = "e";
|
||||
addStartEndKeysForTest(map, first.getBytes(), last.getBytes());
|
||||
|
||||
|
||||
first = "r"; last = "s";
|
||||
addStartEndKeysForTest(map, first.getBytes(), last.getBytes());
|
||||
|
||||
|
@ -380,14 +381,14 @@ public class TestLoadIncrementalHFiles {
|
|||
|
||||
first = "s"; last = "t";
|
||||
addStartEndKeysForTest(map, first.getBytes(), last.getBytes());
|
||||
|
||||
|
||||
first = "u"; last = "w";
|
||||
addStartEndKeysForTest(map, first.getBytes(), last.getBytes());
|
||||
|
||||
byte[][] keysArray = LoadIncrementalHFiles.inferBoundaries(map);
|
||||
byte[][] compare = new byte[3][];
|
||||
compare[0] = "m".getBytes();
|
||||
compare[1] = "r".getBytes();
|
||||
compare[1] = "r".getBytes();
|
||||
compare[2] = "u".getBytes();
|
||||
|
||||
assertEquals(keysArray.length, 3);
|
||||
|
@ -421,5 +422,14 @@ public class TestLoadIncrementalHFiles {
|
|||
+ MAX_FILES_PER_REGION_PER_FAMILY + " hfiles"));
|
||||
}
|
||||
}
|
||||
|
||||
@Test(expected = TableNotFoundException.class)
|
||||
public void testWithoutAnExistingTableAndCreateTableSetToNo() throws Exception {
|
||||
Configuration conf = util.getConfiguration();
|
||||
conf.set(LoadIncrementalHFiles.CREATE_TABLE_CONF_KEY, "no");
|
||||
LoadIncrementalHFiles loader = new LoadIncrementalHFiles(conf);
|
||||
String[] args = { "directory", "nonExistingTable" };
|
||||
loader.run(args);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue