HDFS-2764. TestBackupNode is racy. Contributed by Aaron T. Myers.
git-svn-id: https://svn.apache.org/repos/asf/hadoop/common/trunk@1241780 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
11db1b855f
commit
4d3dc530e8
|
@ -197,6 +197,8 @@ Trunk (unreleased changes)
|
||||||
HDFS-2759. Pre-allocate HDFS edit log files after writing version number.
|
HDFS-2759. Pre-allocate HDFS edit log files after writing version number.
|
||||||
(atm)
|
(atm)
|
||||||
|
|
||||||
|
HDFS-2764. TestBackupNode is racy. (atm)
|
||||||
|
|
||||||
Release 0.23.1 - UNRELEASED
|
Release 0.23.1 - UNRELEASED
|
||||||
|
|
||||||
INCOMPATIBLE CHANGES
|
INCOMPATIBLE CHANGES
|
||||||
|
|
|
@ -34,6 +34,7 @@ import java.util.Properties;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
import org.apache.commons.logging.Log;
|
import org.apache.commons.logging.Log;
|
||||||
|
import org.apache.commons.logging.LogFactory;
|
||||||
import org.apache.hadoop.hdfs.MiniDFSCluster;
|
import org.apache.hadoop.hdfs.MiniDFSCluster;
|
||||||
import org.apache.hadoop.hdfs.server.common.Storage.StorageDirType;
|
import org.apache.hadoop.hdfs.server.common.Storage.StorageDirType;
|
||||||
import org.apache.hadoop.hdfs.server.common.Storage.StorageDirectory;
|
import org.apache.hadoop.hdfs.server.common.Storage.StorageDirectory;
|
||||||
|
@ -62,6 +63,8 @@ import static org.mockito.Mockito.mock;
|
||||||
*/
|
*/
|
||||||
public abstract class FSImageTestUtil {
|
public abstract class FSImageTestUtil {
|
||||||
|
|
||||||
|
public static final Log LOG = LogFactory.getLog(FSImageTestUtil.class);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The position in the fsimage header where the txid is
|
* The position in the fsimage header where the txid is
|
||||||
* written.
|
* written.
|
||||||
|
@ -379,6 +382,8 @@ public abstract class FSImageTestUtil {
|
||||||
List<Integer> txids) {
|
List<Integer> txids) {
|
||||||
|
|
||||||
for (File nameDir : getNameNodeCurrentDirs(cluster)) {
|
for (File nameDir : getNameNodeCurrentDirs(cluster)) {
|
||||||
|
LOG.info("examining name dir with files: " +
|
||||||
|
Joiner.on(",").join(nameDir.listFiles()));
|
||||||
// Should have fsimage_N for the three checkpoints
|
// Should have fsimage_N for the three checkpoints
|
||||||
for (long checkpointTxId : txids) {
|
for (long checkpointTxId : txids) {
|
||||||
File image = new File(nameDir,
|
File image = new File(nameDir,
|
||||||
|
|
|
@ -17,14 +17,14 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.hadoop.hdfs.server.namenode;
|
package org.apache.hadoop.hdfs.server.namenode;
|
||||||
|
|
||||||
|
import static org.junit.Assert.*;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.net.InetSocketAddress;
|
import java.net.InetSocketAddress;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import junit.framework.TestCase;
|
|
||||||
|
|
||||||
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.commons.logging.impl.Log4JLogger;
|
import org.apache.commons.logging.impl.Log4JLogger;
|
||||||
|
@ -41,13 +41,15 @@ import org.apache.hadoop.hdfs.server.namenode.FileJournalManager.EditLogFile;
|
||||||
import org.apache.hadoop.hdfs.server.protocol.NamenodeProtocols;
|
import org.apache.hadoop.hdfs.server.protocol.NamenodeProtocols;
|
||||||
import org.apache.hadoop.test.GenericTestUtils;
|
import org.apache.hadoop.test.GenericTestUtils;
|
||||||
import org.apache.log4j.Level;
|
import org.apache.log4j.Level;
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
import com.google.common.base.Supplier;
|
import com.google.common.base.Supplier;
|
||||||
import com.google.common.collect.ImmutableList;
|
import com.google.common.collect.ImmutableList;
|
||||||
import com.google.common.collect.ImmutableSet;
|
import com.google.common.collect.ImmutableSet;
|
||||||
import com.google.common.collect.Lists;
|
import com.google.common.collect.Lists;
|
||||||
|
|
||||||
public class TestBackupNode extends TestCase {
|
public class TestBackupNode {
|
||||||
public static final Log LOG = LogFactory.getLog(TestBackupNode.class);
|
public static final Log LOG = LogFactory.getLog(TestBackupNode.class);
|
||||||
|
|
||||||
|
|
||||||
|
@ -58,8 +60,8 @@ public class TestBackupNode extends TestCase {
|
||||||
|
|
||||||
static final String BASE_DIR = MiniDFSCluster.getBaseDirectory();
|
static final String BASE_DIR = MiniDFSCluster.getBaseDirectory();
|
||||||
|
|
||||||
protected void setUp() throws Exception {
|
@Before
|
||||||
super.setUp();
|
public void setUp() throws Exception {
|
||||||
File baseDir = new File(BASE_DIR);
|
File baseDir = new File(BASE_DIR);
|
||||||
if(baseDir.exists())
|
if(baseDir.exists())
|
||||||
if(!(FileUtil.fullyDelete(baseDir)))
|
if(!(FileUtil.fullyDelete(baseDir)))
|
||||||
|
@ -90,8 +92,7 @@ public class TestBackupNode extends TestCase {
|
||||||
return (BackupNode)NameNode.createNameNode(new String[]{startupOpt.getName()}, c);
|
return (BackupNode)NameNode.createNameNode(new String[]{startupOpt.getName()}, c);
|
||||||
}
|
}
|
||||||
|
|
||||||
void waitCheckpointDone(
|
void waitCheckpointDone(MiniDFSCluster cluster, long txid) {
|
||||||
MiniDFSCluster cluster, BackupNode backup, long txid) {
|
|
||||||
long thisCheckpointTxId;
|
long thisCheckpointTxId;
|
||||||
do {
|
do {
|
||||||
try {
|
try {
|
||||||
|
@ -99,16 +100,16 @@ public class TestBackupNode extends TestCase {
|
||||||
"checkpoint txid should increase above " + txid);
|
"checkpoint txid should increase above " + txid);
|
||||||
Thread.sleep(1000);
|
Thread.sleep(1000);
|
||||||
} catch (Exception e) {}
|
} catch (Exception e) {}
|
||||||
thisCheckpointTxId = backup.getFSImage().getStorage()
|
// The checkpoint is not done until the nn has received it from the bn
|
||||||
|
thisCheckpointTxId = cluster.getNameNode().getFSImage().getStorage()
|
||||||
.getMostRecentCheckpointTxId();
|
.getMostRecentCheckpointTxId();
|
||||||
|
|
||||||
} while (thisCheckpointTxId < txid);
|
} while (thisCheckpointTxId < txid);
|
||||||
|
|
||||||
// Check that the checkpoint got uploaded to NN successfully
|
// Check that the checkpoint got uploaded to NN successfully
|
||||||
FSImageTestUtil.assertNNHasCheckpoints(cluster,
|
FSImageTestUtil.assertNNHasCheckpoints(cluster,
|
||||||
Collections.singletonList((int)thisCheckpointTxId));
|
Collections.singletonList((int)thisCheckpointTxId));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void testCheckpointNode() throws Exception {
|
public void testCheckpointNode() throws Exception {
|
||||||
testCheckpoint(StartupOption.CHECKPOINT);
|
testCheckpoint(StartupOption.CHECKPOINT);
|
||||||
}
|
}
|
||||||
|
@ -118,6 +119,7 @@ public class TestBackupNode extends TestCase {
|
||||||
* and keep in sync, even while the NN rolls, checkpoints
|
* and keep in sync, even while the NN rolls, checkpoints
|
||||||
* occur, etc.
|
* occur, etc.
|
||||||
*/
|
*/
|
||||||
|
@Test
|
||||||
public void testBackupNodeTailsEdits() throws Exception {
|
public void testBackupNodeTailsEdits() throws Exception {
|
||||||
Configuration conf = new HdfsConfiguration();
|
Configuration conf = new HdfsConfiguration();
|
||||||
MiniDFSCluster cluster = null;
|
MiniDFSCluster cluster = null;
|
||||||
|
@ -235,6 +237,7 @@ public class TestBackupNode extends TestCase {
|
||||||
FSImageTestUtil.assertParallelFilesAreIdentical(dirs, ImmutableSet.of("VERSION"));
|
FSImageTestUtil.assertParallelFilesAreIdentical(dirs, ImmutableSet.of("VERSION"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
public void testBackupNode() throws Exception {
|
public void testBackupNode() throws Exception {
|
||||||
testCheckpoint(StartupOption.BACKUP);
|
testCheckpoint(StartupOption.BACKUP);
|
||||||
}
|
}
|
||||||
|
@ -274,7 +277,7 @@ public class TestBackupNode extends TestCase {
|
||||||
//
|
//
|
||||||
long txid = cluster.getNameNodeRpc().getTransactionID();
|
long txid = cluster.getNameNodeRpc().getTransactionID();
|
||||||
backup = startBackupNode(conf, op, 1);
|
backup = startBackupNode(conf, op, 1);
|
||||||
waitCheckpointDone(cluster, backup, txid);
|
waitCheckpointDone(cluster, txid);
|
||||||
} catch(IOException e) {
|
} catch(IOException e) {
|
||||||
LOG.error("Error in TestBackupNode:", e);
|
LOG.error("Error in TestBackupNode:", e);
|
||||||
assertTrue(e.getLocalizedMessage(), false);
|
assertTrue(e.getLocalizedMessage(), false);
|
||||||
|
@ -309,7 +312,7 @@ public class TestBackupNode extends TestCase {
|
||||||
//
|
//
|
||||||
backup = startBackupNode(conf, op, 1);
|
backup = startBackupNode(conf, op, 1);
|
||||||
long txid = cluster.getNameNodeRpc().getTransactionID();
|
long txid = cluster.getNameNodeRpc().getTransactionID();
|
||||||
waitCheckpointDone(cluster, backup, txid);
|
waitCheckpointDone(cluster, txid);
|
||||||
|
|
||||||
for (int i = 0; i < 10; i++) {
|
for (int i = 0; i < 10; i++) {
|
||||||
fileSys.mkdirs(new Path("file_" + i));
|
fileSys.mkdirs(new Path("file_" + i));
|
||||||
|
@ -317,11 +320,11 @@ public class TestBackupNode extends TestCase {
|
||||||
|
|
||||||
txid = cluster.getNameNodeRpc().getTransactionID();
|
txid = cluster.getNameNodeRpc().getTransactionID();
|
||||||
backup.doCheckpoint();
|
backup.doCheckpoint();
|
||||||
waitCheckpointDone(cluster, backup, txid);
|
waitCheckpointDone(cluster, txid);
|
||||||
|
|
||||||
txid = cluster.getNameNodeRpc().getTransactionID();
|
txid = cluster.getNameNodeRpc().getTransactionID();
|
||||||
backup.doCheckpoint();
|
backup.doCheckpoint();
|
||||||
waitCheckpointDone(cluster, backup, txid);
|
waitCheckpointDone(cluster, txid);
|
||||||
|
|
||||||
// Try BackupNode operations
|
// Try BackupNode operations
|
||||||
InetSocketAddress add = backup.getNameNodeAddress();
|
InetSocketAddress add = backup.getNameNodeAddress();
|
||||||
|
|
Loading…
Reference in New Issue