HBASE-14541 TestHFileOutputFormat.testMRIncrementalLoadWithSplit failed due to too many splits and few retries
This commit is contained in:
parent
57fea77074
commit
fb583dd1ea
|
@ -398,6 +398,7 @@ public class LoadIncrementalHFiles extends Configured implements Tool {
|
|||
}
|
||||
|
||||
int maxRetries = getConf().getInt("hbase.bulkload.retries.number", 10);
|
||||
maxRetries = Math.max(maxRetries, startEndKeys.getFirst().length + 1);
|
||||
if (maxRetries != 0 && count >= maxRetries) {
|
||||
throw new IOException("Retry attempted " + count +
|
||||
" times without completing, bailing out");
|
||||
|
@ -581,7 +582,11 @@ public class LoadIncrementalHFiles extends Configured implements Tool {
|
|||
|
||||
// We use a '_' prefix which is ignored when walking directory trees
|
||||
// above.
|
||||
final Path tmpDir = new Path(item.hfilePath.getParent(), "_tmp");
|
||||
final String TMP_DIR = "_tmp";
|
||||
Path tmpDir = item.hfilePath.getParent();
|
||||
if (!tmpDir.getName().equals(TMP_DIR)) {
|
||||
tmpDir = new Path(tmpDir, TMP_DIR);
|
||||
}
|
||||
|
||||
LOG.info("HFile at " + hfilePath + " no longer fits inside a single " +
|
||||
"region. Splitting...");
|
||||
|
|
|
@ -189,6 +189,28 @@ public class TestLoadIncrementalHFiles {
|
|||
testRegionCrossingHFileSplit(BloomType.ROWCOL);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testSplitALot() throws Exception {
|
||||
runTest("testSplitALot", BloomType.NONE,
|
||||
new byte[][] {
|
||||
Bytes.toBytes("aaaa"), Bytes.toBytes("bbb"),
|
||||
Bytes.toBytes("ccc"), Bytes.toBytes("ddd"),
|
||||
Bytes.toBytes("eee"), Bytes.toBytes("fff"),
|
||||
Bytes.toBytes("ggg"), Bytes.toBytes("hhh"),
|
||||
Bytes.toBytes("iii"), Bytes.toBytes("lll"),
|
||||
Bytes.toBytes("mmm"), Bytes.toBytes("nnn"),
|
||||
Bytes.toBytes("ooo"), Bytes.toBytes("ppp"),
|
||||
Bytes.toBytes("qqq"), Bytes.toBytes("rrr"),
|
||||
Bytes.toBytes("sss"), Bytes.toBytes("ttt"),
|
||||
Bytes.toBytes("uuu"), Bytes.toBytes("vvv"),
|
||||
Bytes.toBytes("zzz"),
|
||||
},
|
||||
new byte[][][] {
|
||||
new byte[][] { Bytes.toBytes("aaaa"), Bytes.toBytes("zzz") },
|
||||
}
|
||||
);
|
||||
}
|
||||
|
||||
private void testRegionCrossingHFileSplit(BloomType bloomType) throws Exception {
|
||||
runTest("testHFileSplit" + bloomType + "Bloom", bloomType,
|
||||
new byte[][] {
|
||||
|
|
Loading…
Reference in New Issue