HBASE-26300 Skip archived master wals during incremental backups (#4932)
Signed-off-by: Bryan Beaudreault <bbeaudreault@apache.org>
This commit is contained in:
parent
e206b974c8
commit
140e0de748
|
@ -53,6 +53,7 @@ import org.apache.hadoop.hbase.client.Admin;
|
||||||
import org.apache.hadoop.hbase.client.Connection;
|
import org.apache.hadoop.hbase.client.Connection;
|
||||||
import org.apache.hadoop.hbase.client.RegionInfo;
|
import org.apache.hadoop.hbase.client.RegionInfo;
|
||||||
import org.apache.hadoop.hbase.client.TableDescriptor;
|
import org.apache.hadoop.hbase.client.TableDescriptor;
|
||||||
|
import org.apache.hadoop.hbase.master.region.MasterRegionFactory;
|
||||||
import org.apache.hadoop.hbase.tool.BulkLoadHFiles;
|
import org.apache.hadoop.hbase.tool.BulkLoadHFiles;
|
||||||
import org.apache.hadoop.hbase.util.CommonFSUtils;
|
import org.apache.hadoop.hbase.util.CommonFSUtils;
|
||||||
import org.apache.hadoop.hbase.util.EnvironmentEdgeManager;
|
import org.apache.hadoop.hbase.util.EnvironmentEdgeManager;
|
||||||
|
@ -359,6 +360,10 @@ public final class BackupUtils {
|
||||||
* @return host name
|
* @return host name
|
||||||
*/
|
*/
|
||||||
public static String parseHostFromOldLog(Path p) {
|
public static String parseHostFromOldLog(Path p) {
|
||||||
|
// Skip master wals
|
||||||
|
if (p.getName().endsWith(MasterRegionFactory.ARCHIVED_WAL_SUFFIX)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
try {
|
try {
|
||||||
String n = p.getName();
|
String n = p.getName();
|
||||||
int idx = n.lastIndexOf(LOGNAME_SEPARATOR);
|
int idx = n.lastIndexOf(LOGNAME_SEPARATOR);
|
||||||
|
|
|
@ -24,8 +24,14 @@ import org.apache.hadoop.fs.FileSystem;
|
||||||
import org.apache.hadoop.fs.Path;
|
import org.apache.hadoop.fs.Path;
|
||||||
import org.apache.hadoop.hbase.HBaseClassTestRule;
|
import org.apache.hadoop.hbase.HBaseClassTestRule;
|
||||||
import org.apache.hadoop.hbase.HBaseTestingUtility;
|
import org.apache.hadoop.hbase.HBaseTestingUtility;
|
||||||
|
import org.apache.hadoop.hbase.HConstants;
|
||||||
|
import org.apache.hadoop.hbase.ServerName;
|
||||||
import org.apache.hadoop.hbase.backup.util.BackupUtils;
|
import org.apache.hadoop.hbase.backup.util.BackupUtils;
|
||||||
|
import org.apache.hadoop.hbase.master.region.MasterRegionFactory;
|
||||||
import org.apache.hadoop.hbase.testclassification.SmallTests;
|
import org.apache.hadoop.hbase.testclassification.SmallTests;
|
||||||
|
import org.apache.hadoop.hbase.util.Addressing;
|
||||||
|
import org.apache.hadoop.hbase.util.CommonFSUtils;
|
||||||
|
import org.apache.hadoop.hbase.util.EnvironmentEdgeManager;
|
||||||
import org.apache.hadoop.security.UserGroupInformation;
|
import org.apache.hadoop.security.UserGroupInformation;
|
||||||
import org.junit.Assert;
|
import org.junit.Assert;
|
||||||
import org.junit.ClassRule;
|
import org.junit.ClassRule;
|
||||||
|
@ -45,7 +51,7 @@ public class TestBackupUtils {
|
||||||
protected static Configuration conf = TEST_UTIL.getConfiguration();
|
protected static Configuration conf = TEST_UTIL.getConfiguration();
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void TestGetBulkOutputDir() {
|
public void testGetBulkOutputDir() {
|
||||||
// Create a user who is not the current user
|
// Create a user who is not the current user
|
||||||
String fooUserName = "foo1234";
|
String fooUserName = "foo1234";
|
||||||
String fooGroupName = "group1";
|
String fooGroupName = "group1";
|
||||||
|
@ -78,4 +84,24 @@ public class TestBackupUtils {
|
||||||
// Make sure the directory is in foo1234's home directory
|
// Make sure the directory is in foo1234's home directory
|
||||||
Assert.assertTrue(bulkOutputDir.toString().startsWith(fooHomeDirectory.toString()));
|
Assert.assertTrue(bulkOutputDir.toString().startsWith(fooHomeDirectory.toString()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testFilesystemWalHostNameParsing() throws IOException {
|
||||||
|
String host = "localhost";
|
||||||
|
int port = 60030;
|
||||||
|
ServerName serverName = ServerName.valueOf(host, port, 1234);
|
||||||
|
Path walRootDir = CommonFSUtils.getWALRootDir(conf);
|
||||||
|
Path oldLogDir = new Path(walRootDir, HConstants.HREGION_OLDLOGDIR_NAME);
|
||||||
|
|
||||||
|
Path testWalPath = new Path(oldLogDir,
|
||||||
|
serverName.toString() + BackupUtils.LOGNAME_SEPARATOR + EnvironmentEdgeManager.currentTime());
|
||||||
|
Path testMasterWalPath =
|
||||||
|
new Path(oldLogDir, testWalPath.getName() + MasterRegionFactory.ARCHIVED_WAL_SUFFIX);
|
||||||
|
|
||||||
|
String parsedHost = BackupUtils.parseHostFromOldLog(testMasterWalPath);
|
||||||
|
Assert.assertNull(parsedHost);
|
||||||
|
|
||||||
|
parsedHost = BackupUtils.parseHostFromOldLog(testWalPath);
|
||||||
|
Assert.assertEquals(parsedHost, host + Addressing.HOSTNAME_PORT_SEPARATOR + port);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue