From 30ecf5ae7886dfa5265bc580c5464c86fa8f2866 Mon Sep 17 00:00:00 2001 From: tedyu Date: Fri, 14 Nov 2014 16:37:19 -0800 Subject: [PATCH] HBASE-12478 HBASE-10141 and MIN_VERSIONS are not compatible --- .../hadoop/hbase/regionserver/HStore.java | 5 ++++ .../hadoop/hbase/regionserver/TestStore.java | 25 +++++++++++++++---- 2 files changed, 25 insertions(+), 5 deletions(-) diff --git a/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/HStore.java b/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/HStore.java index 5c06756b960..eb51c50c824 100644 --- a/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/HStore.java +++ b/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/HStore.java @@ -1517,6 +1517,11 @@ public class HStore implements Store { private void removeUnneededFiles() throws IOException { if (!conf.getBoolean("hbase.store.delete.expired.storefile", true)) return; + if (getFamily().getMinVersions() > 0) { + LOG.debug("Skipping expired store file removal due to min version being " + + getFamily().getMinVersions()); + return; + } this.lock.readLock().lock(); Collection delSfs = null; try { diff --git a/hbase-server/src/test/java/org/apache/hadoop/hbase/regionserver/TestStore.java b/hbase-server/src/test/java/org/apache/hadoop/hbase/regionserver/TestStore.java index a2c99b35ca6..a6f13f061c7 100644 --- a/hbase-server/src/test/java/org/apache/hadoop/hbase/regionserver/TestStore.java +++ b/hbase-server/src/test/java/org/apache/hadoop/hbase/regionserver/TestStore.java @@ -279,6 +279,14 @@ public class TestStore { @Test public void testDeleteExpiredStoreFiles() throws Exception { + testDeleteExpiredStoreFiles(0); + testDeleteExpiredStoreFiles(1); + } + + /* + * @param minVersions the MIN_VERSIONS for the column family + */ + public void testDeleteExpiredStoreFiles(int minVersions) throws Exception { int storeFileNum = 4; int ttl = 4; IncrementingEnvironmentEdge edge = new IncrementingEnvironmentEdge(); @@ -291,6 +299,7 @@ public class TestStore { conf.setInt(CompactionConfiguration.HBASE_HSTORE_COMPACTION_MIN_KEY, 5); HColumnDescriptor hcd = new HColumnDescriptor(family); + hcd.setMinVersions(minVersions); hcd.setTimeToLive(ttl); init(name.getMethodName(), conf, hcd); @@ -319,10 +328,14 @@ public class TestStore { assertNull(this.store.requestCompaction()); Collection sfs = this.store.getStorefiles(); // Ensure i files are gone. - assertEquals(storeFileNum - i, sfs.size()); - // Ensure only non-expired files remain. - for (StoreFile sf : sfs) { - assertTrue(sf.getReader().getMaxTimestamp() >= (edge.currentTime() - storeTtl)); + if (minVersions == 0) { + assertEquals(storeFileNum - i, sfs.size()); + // Ensure only non-expired files remain. + for (StoreFile sf : sfs) { + assertTrue(sf.getReader().getMaxTimestamp() >= (edge.currentTime() - storeTtl)); + } + } else { + assertEquals(storeFileNum, sfs.size()); } // Let the next store file expired. edge.incrementTime(sleepTime); @@ -330,7 +343,9 @@ public class TestStore { assertNull(this.store.requestCompaction()); Collection sfs = this.store.getStorefiles(); // Assert the last expired file is not removed. - assertEquals(1, sfs.size()); + if (minVersions == 0) { + assertEquals(1, sfs.size()); + } long ts = sfs.iterator().next().getReader().getMaxTimestamp(); assertTrue(ts < (edge.currentTime() - storeTtl)); }