HBASE-19794 TestZooKeeper hangs

Kill backup master first

Add some cleanup around NamespaceManager

Shorten the timeout waiting on namespace manager as workaround
until we have better soln for interrupting ongoing client rpcs.
Do it in general for all tests.

Signed-off-by: zhangduo <zhangduo@apache.org>
This commit is contained in:
Michael Stack 2018-01-20 20:11:10 +08:00 committed by zhangduo
parent 7fe4aa6fe4
commit 27d00f5861
7 changed files with 72 additions and 23 deletions

View File

@ -1802,4 +1802,10 @@ possible configurations would overwhelm and obscure the important.
Number of rows in a batch operation above which a warning will be logged. Number of rows in a batch operation above which a warning will be logged.
</description> </description>
</property> </property>
<property>
<name>hbase.master.wait.on.service.seconds</name>
<value>30</value>
<description>Default is 5 minutes. Make it 30 seconds for tests. See
HBASE-19794 for some context.</description>
</property>
</configuration> </configuration>

View File

@ -76,6 +76,10 @@ public class ZKNamespaceManager extends ZKListener {
} }
} }
public void stop() throws IOException {
this.watcher.unregisterListener(this);
}
public NamespaceDescriptor get(String name) { public NamespaceDescriptor get(String name) {
return cache.get(name); return cache.get(name);
} }

View File

@ -69,6 +69,10 @@ class ClusterSchemaServiceImpl extends AbstractService implements ClusterSchemaS
protected void doStop() { protected void doStop() {
// This is no stop for the table manager. // This is no stop for the table manager.
notifyStopped(); notifyStopped();
TableNamespaceManager tnsm = getTableNamespaceManager();
if (tnsm != null) {
tnsm.stop("Stopping");
}
} }
@Override @Override

View File

@ -2692,9 +2692,11 @@ public class HMaster extends HRegionServer implements MasterServices {
@Override @Override
public void stop(String msg) { public void stop(String msg) {
super.stop(msg); if (!isStopped()) {
if (this.activeMasterManager != null) { super.stop(msg);
this.activeMasterManager.stop(); if (this.activeMasterManager != null) {
this.activeMasterManager.stop();
}
} }
} }

View File

@ -32,6 +32,7 @@ import org.apache.hadoop.hbase.DoNotRetryIOException;
import org.apache.hadoop.hbase.HTableDescriptor; import org.apache.hadoop.hbase.HTableDescriptor;
import org.apache.hadoop.hbase.MetaTableAccessor; import org.apache.hadoop.hbase.MetaTableAccessor;
import org.apache.hadoop.hbase.NamespaceDescriptor; import org.apache.hadoop.hbase.NamespaceDescriptor;
import org.apache.hadoop.hbase.Stoppable;
import org.apache.hadoop.hbase.TableName; import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.hbase.ZKNamespaceManager; import org.apache.hadoop.hbase.ZKNamespaceManager;
import org.apache.hadoop.hbase.client.Delete; import org.apache.hadoop.hbase.client.Delete;
@ -68,8 +69,9 @@ import org.slf4j.LoggerFactory;
@edu.umd.cs.findbugs.annotations.SuppressWarnings(value="IS2_INCONSISTENT_SYNC", @edu.umd.cs.findbugs.annotations.SuppressWarnings(value="IS2_INCONSISTENT_SYNC",
justification="TODO: synchronize access on nsTable but it is done in tiers above and this " + justification="TODO: synchronize access on nsTable but it is done in tiers above and this " +
"class is going away/shrinking") "class is going away/shrinking")
public class TableNamespaceManager { public class TableNamespaceManager implements Stoppable {
private static final Logger LOG = LoggerFactory.getLogger(TableNamespaceManager.class); private static final Logger LOG = LoggerFactory.getLogger(TableNamespaceManager.class);
private volatile boolean stopped = false;
private Configuration conf; private Configuration conf;
private MasterServices masterServices; private MasterServices masterServices;
@ -368,4 +370,27 @@ public class TableNamespaceManager {
} }
return maxRegions; return maxRegions;
} }
@Override
public boolean isStopped() {
return this.stopped;
}
@Override
public void stop(String why) {
if (this.stopped) {
return;
}
try {
this.zkNamespaceManager.stop();
} catch (IOException ioe) {
LOG.warn("Failed NamespaceManager close", ioe);
}
try {
this.nsTable.close();
} catch (IOException ioe) {
LOG.warn("Failed Namespace Table close", ioe);
}
this.stopped = true;
}
} }

View File

@ -837,12 +837,22 @@ public class MiniHBaseCluster extends HBaseCluster {
* impossible to bring the mini-cluster back for clean shutdown. * impossible to bring the mini-cluster back for clean shutdown.
*/ */
public void killAll() { public void killAll() {
// Do backups first.
MasterThread activeMaster = null;
for (MasterThread masterThread : getMasterThreads()) {
if (!masterThread.getMaster().isActiveMaster()) {
masterThread.getMaster().abort("killAll");
} else {
activeMaster = masterThread;
}
}
// Do active after.
if (activeMaster != null) {
activeMaster.getMaster().abort("killAll");
}
for (RegionServerThread rst : getRegionServerThreads()) { for (RegionServerThread rst : getRegionServerThreads()) {
rst.getRegionServer().abort("killAll"); rst.getRegionServer().abort("killAll");
} }
for (MasterThread masterThread : getMasterThreads()) {
masterThread.getMaster().abort("killAll", new Throwable());
}
} }
@Override @Override

View File

@ -27,10 +27,8 @@ import java.io.IOException;
import java.util.concurrent.ExecutionException; import java.util.concurrent.ExecutionException;
import java.util.concurrent.atomic.AtomicBoolean; import java.util.concurrent.atomic.AtomicBoolean;
import java.util.stream.IntStream; import java.util.stream.IntStream;
import org.apache.commons.io.IOUtils; import org.apache.commons.io.IOUtils;
import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.ClusterId;
import org.apache.hadoop.hbase.HBaseTestingUtility; import org.apache.hadoop.hbase.HBaseTestingUtility;
import org.apache.hadoop.hbase.HConstants; import org.apache.hadoop.hbase.HConstants;
import org.apache.hadoop.hbase.HRegionLocation; import org.apache.hadoop.hbase.HRegionLocation;
@ -104,7 +102,7 @@ public class TestZKAsyncRegistry {
String expectedClusterId = TEST_UTIL.getHBaseCluster().getMaster().getClusterId(); String expectedClusterId = TEST_UTIL.getHBaseCluster().getMaster().getClusterId();
assertEquals("Expected " + expectedClusterId + ", found=" + clusterId, assertEquals("Expected " + expectedClusterId + ", found=" + clusterId,
expectedClusterId, clusterId); expectedClusterId, clusterId);
assertEquals(TEST_UTIL.getHBaseCluster().getClusterStatus().getServersSize(), assertEquals(TEST_UTIL.getHBaseCluster().getClusterMetrics().getLiveServerMetrics().size(),
REGISTRY.getCurrentNrHRS().get().intValue()); REGISTRY.getCurrentNrHRS().get().intValue());
assertEquals(TEST_UTIL.getHBaseCluster().getMaster().getServerName(), assertEquals(TEST_UTIL.getHBaseCluster().getMaster().getServerName(),
REGISTRY.getMasterAddress().get()); REGISTRY.getMasterAddress().get());
@ -122,19 +120,19 @@ public class TestZKAsyncRegistry {
@Test @Test
public void testIndependentZKConnections() throws IOException { public void testIndependentZKConnections() throws IOException {
ReadOnlyZKClient zk1 = REGISTRY.getZKClient(); try (ReadOnlyZKClient zk1 = REGISTRY.getZKClient()) {
Configuration otherConf = new Configuration(TEST_UTIL.getConfiguration());
Configuration otherConf = new Configuration(TEST_UTIL.getConfiguration()); otherConf.set(HConstants.ZOOKEEPER_QUORUM, "127.0.0.1");
otherConf.set(HConstants.ZOOKEEPER_QUORUM, "127.0.0.1"); try (ZKAsyncRegistry otherRegistry = new ZKAsyncRegistry(otherConf)) {
try (ZKAsyncRegistry otherRegistry = new ZKAsyncRegistry(otherConf)) { ReadOnlyZKClient zk2 = otherRegistry.getZKClient();
ReadOnlyZKClient zk2 = otherRegistry.getZKClient(); assertNotSame("Using a different configuration / quorum should result in different " +
"backing zk connection.", zk1, zk2);
assertNotSame("Using a different configuration / quorum should result in different backing " + assertNotEquals(
"zk connection.", "Using a different configrution / quorum should be reflected in the zk connection.",
zk1, zk2); zk1.getConnectString(), zk2.getConnectString());
assertNotEquals( }
"Using a different configrution / quorum should be reflected in the " + "zk connection.", } finally {
zk1.getConnectString(), zk2.getConnectString()); LOG.info("DONE!");
} }
} }
} }