HBASE-6439 Ignore .archive directory as a table
git-svn-id: https://svn.apache.org/repos/asf/hbase/trunk@1393916 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
1ca8d32e63
commit
7d2479983a
|
@ -619,12 +619,6 @@ public final class HConstants {
|
||||||
*/
|
*/
|
||||||
public static final float HBASE_CLUSTER_MINIMUM_MEMORY_THRESHOLD = 0.2f;
|
public static final float HBASE_CLUSTER_MINIMUM_MEMORY_THRESHOLD = 0.2f;
|
||||||
|
|
||||||
public static final List<String> HBASE_NON_USER_TABLE_DIRS = new ArrayList<String>(
|
|
||||||
Arrays.asList(new String[]{ HREGION_LOGDIR_NAME, HREGION_OLDLOGDIR_NAME,
|
|
||||||
CORRUPT_DIR_NAME, Bytes.toString(META_TABLE_NAME),
|
|
||||||
Bytes.toString(ROOT_TABLE_NAME), SPLIT_LOGDIR_NAME,
|
|
||||||
HBCK_SIDELINEDIR_NAME }));
|
|
||||||
|
|
||||||
public static final Pattern CP_HTD_ATTR_KEY_PATTERN = Pattern.compile
|
public static final Pattern CP_HTD_ATTR_KEY_PATTERN = Pattern.compile
|
||||||
("^coprocessor\\$([0-9]+)$", Pattern.CASE_INSENSITIVE);
|
("^coprocessor\\$([0-9]+)$", Pattern.CASE_INSENSITIVE);
|
||||||
public static final Pattern CP_HTD_ATTR_VALUE_PATTERN =
|
public static final Pattern CP_HTD_ATTR_VALUE_PATTERN =
|
||||||
|
@ -699,9 +693,6 @@ public final class HConstants {
|
||||||
/** delimiter used between portions of a region name */
|
/** delimiter used between portions of a region name */
|
||||||
public static final int DELIMITER = ',';
|
public static final int DELIMITER = ',';
|
||||||
|
|
||||||
/** Configuration key for the directory to backup HFiles for a table */
|
|
||||||
public static final String HFILE_ARCHIVE_DIRECTORY = "hbase.table.archive.directory";
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* QOS attributes: these attributes are used to demarcate RPC call processing
|
* QOS attributes: these attributes are used to demarcate RPC call processing
|
||||||
* by different set of handlers. For example, HIGH_QOS tagged methods are
|
* by different set of handlers. For example, HIGH_QOS tagged methods are
|
||||||
|
@ -712,6 +703,14 @@ public final class HConstants {
|
||||||
public static final int HIGH_QOS = 100;
|
public static final int HIGH_QOS = 100;
|
||||||
public static final int REPLICATION_QOS = 5; // normal_QOS < replication_QOS < high_QOS
|
public static final int REPLICATION_QOS = 5; // normal_QOS < replication_QOS < high_QOS
|
||||||
|
|
||||||
|
/** Directory under /hbase where archived hfiles are stored */
|
||||||
|
public static final String HFILE_ARCHIVE_DIRECTORY = ".archive";
|
||||||
|
|
||||||
|
public static final List<String> HBASE_NON_USER_TABLE_DIRS = new ArrayList<String>(
|
||||||
|
Arrays.asList(new String[] { HREGION_LOGDIR_NAME, HREGION_OLDLOGDIR_NAME, CORRUPT_DIR_NAME,
|
||||||
|
Bytes.toString(META_TABLE_NAME), Bytes.toString(ROOT_TABLE_NAME), SPLIT_LOGDIR_NAME,
|
||||||
|
HBCK_SIDELINEDIR_NAME, HFILE_ARCHIVE_DIRECTORY }));
|
||||||
|
|
||||||
private HConstants() {
|
private HConstants() {
|
||||||
// Can't be instantiated with this ctor.
|
// Can't be instantiated with this ctor.
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,34 +21,28 @@ package org.apache.hadoop.hbase.io;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.regex.Matcher;
|
import java.util.regex.Matcher;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
import java.security.MessageDigest;
|
|
||||||
import java.security.NoSuchAlgorithmException;
|
|
||||||
|
|
||||||
import org.apache.commons.codec.binary.Hex;
|
|
||||||
import org.apache.commons.logging.Log;
|
import org.apache.commons.logging.Log;
|
||||||
import org.apache.commons.logging.LogFactory;
|
import org.apache.commons.logging.LogFactory;
|
||||||
import org.apache.hadoop.classification.InterfaceAudience;
|
import org.apache.hadoop.classification.InterfaceAudience;
|
||||||
import org.apache.hadoop.conf.Configuration;
|
import org.apache.hadoop.conf.Configuration;
|
||||||
import org.apache.hadoop.fs.FileSystem;
|
import org.apache.hadoop.fs.FileSystem;
|
||||||
import org.apache.hadoop.fs.FileStatus;
|
|
||||||
import org.apache.hadoop.fs.Path;
|
import org.apache.hadoop.fs.Path;
|
||||||
import org.apache.hadoop.hbase.HRegionInfo;
|
import org.apache.hadoop.hbase.HRegionInfo;
|
||||||
import org.apache.hadoop.hbase.regionserver.HRegion;
|
import org.apache.hadoop.hbase.regionserver.HRegion;
|
||||||
import org.apache.hadoop.hbase.util.Bytes;
|
|
||||||
import org.apache.hadoop.hbase.util.HFileArchiveUtil;
|
|
||||||
import org.apache.hadoop.hbase.util.FSUtils;
|
import org.apache.hadoop.hbase.util.FSUtils;
|
||||||
|
import org.apache.hadoop.hbase.util.HFileArchiveUtil;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* HFileLink describes a link to an hfile.
|
* HFileLink describes a link to an hfile.
|
||||||
*
|
*
|
||||||
* An hfile can be served from a region or from the hfile archive directory as
|
* An hfile can be served from a region or from the hfile archive directory (/hbase/.archive)
|
||||||
* specified by {@value HConstants.HFILE_ARCHIVE_DIRECTORY} conf property.
|
|
||||||
* HFileLink allows to access the referenced hfile regardless of the location where it is.
|
* HFileLink allows to access the referenced hfile regardless of the location where it is.
|
||||||
*
|
*
|
||||||
* <p>Searches for hfiles in the following order and locations:
|
* <p>Searches for hfiles in the following order and locations:
|
||||||
* <ul>
|
* <ul>
|
||||||
* <li>/hbase/table/region/cf/hfile</li>
|
* <li>/hbase/table/region/cf/hfile</li>
|
||||||
* <li>/hbase/archive/table/region/cf/hfile</li>
|
* <li>/hbase/.archive/table/region/cf/hfile</li>
|
||||||
* </ul>
|
* </ul>
|
||||||
*
|
*
|
||||||
* The link checks first in the original path if it is not present
|
* The link checks first in the original path if it is not present
|
||||||
|
@ -145,7 +139,7 @@ public class HFileLink extends FileLink {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The returned path can be the "original" file path like: /hbase/table/region/cf/hfile
|
* The returned path can be the "original" file path like: /hbase/table/region/cf/hfile
|
||||||
* or a path to the archived file like: /hbase/archive/table/region/cf/hfile
|
* or a path to the archived file like: /hbase/.archive/table/region/cf/hfile
|
||||||
*
|
*
|
||||||
* @param fs {@link FileSystem} on which to check the HFileLink
|
* @param fs {@link FileSystem} on which to check the HFileLink
|
||||||
* @param conf {@link Configuration} from which to extract specific archive locations
|
* @param conf {@link Configuration} from which to extract specific archive locations
|
||||||
|
@ -161,7 +155,7 @@ public class HFileLink extends FileLink {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The returned path can be the "original" file path like: /hbase/table/region/cf/hfile
|
* The returned path can be the "original" file path like: /hbase/table/region/cf/hfile
|
||||||
* or a path to the archived file like: /hbase/archive/table/region/cf/hfile
|
* or a path to the archived file like: /hbase/.archive/table/region/cf/hfile
|
||||||
*
|
*
|
||||||
* @param fs {@link FileSystem} on which to check the HFileLink
|
* @param fs {@link FileSystem} on which to check the HFileLink
|
||||||
* @param rootdir root hbase directory
|
* @param rootdir root hbase directory
|
||||||
|
|
|
@ -33,8 +33,6 @@ import org.apache.hadoop.hbase.regionserver.HStore;
|
||||||
* Helper class for all utilities related to archival/retrieval of HFiles
|
* Helper class for all utilities related to archival/retrieval of HFiles
|
||||||
*/
|
*/
|
||||||
public class HFileArchiveUtil {
|
public class HFileArchiveUtil {
|
||||||
public static final String DEFAULT_HFILE_ARCHIVE_DIRECTORY = ".archive";
|
|
||||||
|
|
||||||
private HFileArchiveUtil() {
|
private HFileArchiveUtil() {
|
||||||
// non-external instantiation - util class
|
// non-external instantiation - util class
|
||||||
}
|
}
|
||||||
|
@ -78,7 +76,7 @@ public class HFileArchiveUtil {
|
||||||
*/
|
*/
|
||||||
public static Path getStoreArchivePath(Configuration conf, HRegionInfo region, Path tabledir,
|
public static Path getStoreArchivePath(Configuration conf, HRegionInfo region, Path tabledir,
|
||||||
byte[] family) {
|
byte[] family) {
|
||||||
Path tableArchiveDir = getTableArchivePath(conf, tabledir);
|
Path tableArchiveDir = getTableArchivePath(tabledir);
|
||||||
return HStore.getStoreHomedir(tableArchiveDir,
|
return HStore.getStoreHomedir(tableArchiveDir,
|
||||||
HRegionInfo.encodeRegionName(region.getRegionName()), family);
|
HRegionInfo.encodeRegionName(region.getRegionName()), family);
|
||||||
}
|
}
|
||||||
|
@ -93,7 +91,7 @@ public class HFileArchiveUtil {
|
||||||
*/
|
*/
|
||||||
public static Path getRegionArchiveDir(Configuration conf, Path tabledir, Path regiondir) {
|
public static Path getRegionArchiveDir(Configuration conf, Path tabledir, Path regiondir) {
|
||||||
// get the archive directory for a table
|
// get the archive directory for a table
|
||||||
Path archiveDir = getTableArchivePath(conf, tabledir);
|
Path archiveDir = getTableArchivePath(tabledir);
|
||||||
|
|
||||||
// then add on the region path under the archive
|
// then add on the region path under the archive
|
||||||
String encodedRegionName = regiondir.getName();
|
String encodedRegionName = regiondir.getName();
|
||||||
|
@ -103,19 +101,15 @@ public class HFileArchiveUtil {
|
||||||
/**
|
/**
|
||||||
* Get the path to the table archive directory based on the configured archive directory.
|
* Get the path to the table archive directory based on the configured archive directory.
|
||||||
* <p>
|
* <p>
|
||||||
* Assumed that the table should already be archived.
|
* Get the path to the table's archive directory.
|
||||||
* @param conf {@link Configuration} to read the archive directory property. Can be null
|
* <p>
|
||||||
|
* Generally of the form: /hbase/.archive/[tablename]
|
||||||
* @param tabledir directory of the table to be archived. Cannot be null.
|
* @param tabledir directory of the table to be archived. Cannot be null.
|
||||||
* @return {@link Path} to the archive directory for the table
|
* @return {@link Path} to the archive directory for the table
|
||||||
*/
|
*/
|
||||||
public static Path getTableArchivePath(Configuration conf, Path tabledir) {
|
public static Path getTableArchivePath(Path tabledir) {
|
||||||
String archiveName = getConfiguredArchiveDirName(conf);
|
|
||||||
Path root = tabledir.getParent();
|
Path root = tabledir.getParent();
|
||||||
// now build the archive directory path
|
return new Path(new Path(root,HConstants.HFILE_ARCHIVE_DIRECTORY), tabledir.getName());
|
||||||
// first the top-level archive directory
|
|
||||||
// generally "/hbase/.archive/[table]
|
|
||||||
return archiveName.length() == 0 ? new Path(root, tabledir) : new Path(new Path(root,
|
|
||||||
archiveName), tabledir.getName());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -131,18 +125,6 @@ public class HFileArchiveUtil {
|
||||||
return new Path(getArchivePath(conf), tableName);
|
return new Path(getArchivePath(conf), tableName);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the archive directory as per the configuration
|
|
||||||
* @param conf {@link Configuration} to read the archive directory from (can be null, in which
|
|
||||||
* case you get the default value). Can be null.
|
|
||||||
* @return the configured archived directory or the default specified by
|
|
||||||
* {@value HFileArchiveUtil#DEFAULT_HFILE_ARCHIVE_DIRECTORY}
|
|
||||||
*/
|
|
||||||
public static String getConfiguredArchiveDirName(Configuration conf) {
|
|
||||||
return conf == null ? HFileArchiveUtil.DEFAULT_HFILE_ARCHIVE_DIRECTORY : conf.get(
|
|
||||||
HConstants.HFILE_ARCHIVE_DIRECTORY, HFileArchiveUtil.DEFAULT_HFILE_ARCHIVE_DIRECTORY);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the full path to the archive directory on the configured {@link FileSystem}
|
* Get the full path to the archive directory on the configured {@link FileSystem}
|
||||||
* @param conf to look for archive directory name and root directory. Cannot be null. Notes for
|
* @param conf to look for archive directory name and root directory. Cannot be null. Notes for
|
||||||
|
@ -151,6 +133,6 @@ public class HFileArchiveUtil {
|
||||||
* @throws IOException if an unexpected error occurs
|
* @throws IOException if an unexpected error occurs
|
||||||
*/
|
*/
|
||||||
public static Path getArchivePath(Configuration conf) throws IOException {
|
public static Path getArchivePath(Configuration conf) throws IOException {
|
||||||
return new Path(FSUtils.getRootDir(conf), getConfiguredArchiveDirName(conf));
|
return new Path(FSUtils.getRootDir(conf), HConstants.HFILE_ARCHIVE_DIRECTORY);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -34,6 +34,7 @@ import org.apache.hadoop.fs.FileSystem;
|
||||||
import org.apache.hadoop.fs.Path;
|
import org.apache.hadoop.fs.Path;
|
||||||
import org.apache.hadoop.hbase.HBaseTestingUtility;
|
import org.apache.hadoop.hbase.HBaseTestingUtility;
|
||||||
import org.apache.hadoop.hbase.HColumnDescriptor;
|
import org.apache.hadoop.hbase.HColumnDescriptor;
|
||||||
|
import org.apache.hadoop.hbase.HConstants;
|
||||||
import org.apache.hadoop.hbase.MediumTests;
|
import org.apache.hadoop.hbase.MediumTests;
|
||||||
import org.apache.hadoop.hbase.Stoppable;
|
import org.apache.hadoop.hbase.Stoppable;
|
||||||
import org.apache.hadoop.hbase.client.Put;
|
import org.apache.hadoop.hbase.client.Put;
|
||||||
|
@ -277,7 +278,7 @@ public class TestZooKeeperTableArchiveClient {
|
||||||
}
|
}
|
||||||
|
|
||||||
private Path getArchiveDir() throws IOException {
|
private Path getArchiveDir() throws IOException {
|
||||||
return new Path(UTIL.getDataTestDir(), HFileArchiveUtil.DEFAULT_HFILE_ARCHIVE_DIRECTORY);
|
return new Path(UTIL.getDataTestDir(), HConstants.HFILE_ARCHIVE_DIRECTORY);
|
||||||
}
|
}
|
||||||
|
|
||||||
private Path getTableDir(String tableName) throws IOException {
|
private Path getTableDir(String tableName) throws IOException {
|
||||||
|
|
|
@ -26,11 +26,11 @@ import org.apache.hadoop.fs.FileStatus;
|
||||||
import org.apache.hadoop.fs.FileSystem;
|
import org.apache.hadoop.fs.FileSystem;
|
||||||
import org.apache.hadoop.fs.Path;
|
import org.apache.hadoop.fs.Path;
|
||||||
import org.apache.hadoop.hbase.HBaseTestingUtility;
|
import org.apache.hadoop.hbase.HBaseTestingUtility;
|
||||||
|
import org.apache.hadoop.hbase.HConstants;
|
||||||
import org.apache.hadoop.hbase.Server;
|
import org.apache.hadoop.hbase.Server;
|
||||||
import org.apache.hadoop.hbase.ServerName;
|
import org.apache.hadoop.hbase.ServerName;
|
||||||
import org.apache.hadoop.hbase.SmallTests;
|
import org.apache.hadoop.hbase.SmallTests;
|
||||||
import org.apache.hadoop.hbase.catalog.CatalogTracker;
|
import org.apache.hadoop.hbase.catalog.CatalogTracker;
|
||||||
import org.apache.hadoop.hbase.util.HFileArchiveUtil;
|
|
||||||
import org.apache.hadoop.hbase.zookeeper.ZooKeeperWatcher;
|
import org.apache.hadoop.hbase.zookeeper.ZooKeeperWatcher;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.experimental.categories.Category;
|
import org.junit.experimental.categories.Category;
|
||||||
|
@ -48,8 +48,7 @@ public class TestHFileCleaner {
|
||||||
long ttl = 2000;
|
long ttl = 2000;
|
||||||
conf.setLong(TimeToLiveHFileCleaner.TTL_CONF_KEY, ttl);
|
conf.setLong(TimeToLiveHFileCleaner.TTL_CONF_KEY, ttl);
|
||||||
Server server = new DummyServer();
|
Server server = new DummyServer();
|
||||||
Path archivedHfileDir = new Path(TEST_UTIL.getDataTestDir(),
|
Path archivedHfileDir = new Path(TEST_UTIL.getDataTestDir(), HConstants.HFILE_ARCHIVE_DIRECTORY);
|
||||||
HFileArchiveUtil.getConfiguredArchiveDirName(conf));
|
|
||||||
FileSystem fs = FileSystem.get(conf);
|
FileSystem fs = FileSystem.get(conf);
|
||||||
HFileCleaner cleaner = new HFileCleaner(1000, server, conf, fs, archivedHfileDir);
|
HFileCleaner cleaner = new HFileCleaner(1000, server, conf, fs, archivedHfileDir);
|
||||||
|
|
||||||
|
|
|
@ -252,5 +252,18 @@ public class TestFSTableDescriptors {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testReadingArchiveDirectoryFromFS() throws IOException {
|
||||||
|
FileSystem fs = FileSystem.get(UTIL.getConfiguration());
|
||||||
|
try {
|
||||||
|
new FSTableDescriptors(fs, FSUtils.getRootDir(UTIL.getConfiguration()))
|
||||||
|
.get(HConstants.HFILE_ARCHIVE_DIRECTORY);
|
||||||
|
fail("Shouldn't be able to read a table descriptor for the archive directory.");
|
||||||
|
} catch (IOException e) {
|
||||||
|
LOG.debug("Correctly got error when reading a table descriptor from the archive directory: "
|
||||||
|
+ e.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -35,26 +35,10 @@ import org.mockito.Mockito;
|
||||||
@Category(SmallTests.class)
|
@Category(SmallTests.class)
|
||||||
public class TestHFileArchiveUtil {
|
public class TestHFileArchiveUtil {
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testGetConfiguredArchiveDir() {
|
|
||||||
assertEquals(HFileArchiveUtil.DEFAULT_HFILE_ARCHIVE_DIRECTORY,
|
|
||||||
HFileArchiveUtil.getConfiguredArchiveDirName(null));
|
|
||||||
Configuration conf = new Configuration();
|
|
||||||
assertEquals(HFileArchiveUtil.DEFAULT_HFILE_ARCHIVE_DIRECTORY,
|
|
||||||
HFileArchiveUtil.getConfiguredArchiveDirName(conf));
|
|
||||||
conf.set(HConstants.HFILE_ARCHIVE_DIRECTORY, "");
|
|
||||||
assertEquals("", HFileArchiveUtil.getConfiguredArchiveDirName(conf));
|
|
||||||
String archiveDir = "somearchive";
|
|
||||||
conf.set(HConstants.HFILE_ARCHIVE_DIRECTORY, archiveDir);
|
|
||||||
assertEquals(archiveDir, HFileArchiveUtil.getConfiguredArchiveDirName(conf));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testGetTableArchivePath() {
|
public void testGetTableArchivePath() {
|
||||||
assertNotNull(HFileArchiveUtil.getTableArchivePath(null, new Path("table")));
|
assertNotNull(HFileArchiveUtil.getTableArchivePath(new Path("table")));
|
||||||
Configuration conf = new Configuration();
|
assertNotNull(HFileArchiveUtil.getTableArchivePath(new Path("root", new Path("table"))));
|
||||||
conf.set(HConstants.HFILE_ARCHIVE_DIRECTORY, "");
|
|
||||||
assertNotNull(HFileArchiveUtil.getTableArchivePath(conf, new Path("root", new Path("table"))));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -62,10 +46,6 @@ public class TestHFileArchiveUtil {
|
||||||
Configuration conf = new Configuration();
|
Configuration conf = new Configuration();
|
||||||
FSUtils.setRootDir(conf, new Path("root"));
|
FSUtils.setRootDir(conf, new Path("root"));
|
||||||
assertNotNull(HFileArchiveUtil.getArchivePath(conf));
|
assertNotNull(HFileArchiveUtil.getArchivePath(conf));
|
||||||
String archiveDir = "somearchive";
|
|
||||||
conf.set(HConstants.HFILE_ARCHIVE_DIRECTORY, archiveDir);
|
|
||||||
assertEquals(new Path(FSUtils.getRootDir(conf), archiveDir),
|
|
||||||
HFileArchiveUtil.getArchivePath(conf));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -84,8 +64,6 @@ public class TestHFileArchiveUtil {
|
||||||
assertNotNull(HFileArchiveUtil.getStoreArchivePath(conf, region, tabledir, family));
|
assertNotNull(HFileArchiveUtil.getStoreArchivePath(conf, region, tabledir, family));
|
||||||
conf = new Configuration();
|
conf = new Configuration();
|
||||||
assertNotNull(HFileArchiveUtil.getStoreArchivePath(conf, region, tabledir, family));
|
assertNotNull(HFileArchiveUtil.getStoreArchivePath(conf, region, tabledir, family));
|
||||||
conf.set(HConstants.HFILE_ARCHIVE_DIRECTORY, "archiveDir");
|
|
||||||
assertNotNull(HFileArchiveUtil.getStoreArchivePath(conf, region, tabledir, family));
|
|
||||||
|
|
||||||
// do a little mocking of a region to get the same results
|
// do a little mocking of a region to get the same results
|
||||||
HRegion mockRegion = Mockito.mock(HRegion.class);
|
HRegion mockRegion = Mockito.mock(HRegion.class);
|
||||||
|
@ -95,8 +73,5 @@ public class TestHFileArchiveUtil {
|
||||||
assertNotNull(HFileArchiveUtil.getStoreArchivePath(null, mockRegion, family));
|
assertNotNull(HFileArchiveUtil.getStoreArchivePath(null, mockRegion, family));
|
||||||
conf = new Configuration();
|
conf = new Configuration();
|
||||||
assertNotNull(HFileArchiveUtil.getStoreArchivePath(conf, mockRegion, family));
|
assertNotNull(HFileArchiveUtil.getStoreArchivePath(conf, mockRegion, family));
|
||||||
conf.set(HConstants.HFILE_ARCHIVE_DIRECTORY, "archiveDir");
|
|
||||||
assertNotNull(HFileArchiveUtil.getStoreArchivePath(conf, mockRegion, family));
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue