MAPREDUCE-6473. Job submission can take a long time during Cluster initialization. Contributed by Kuhu Shukla

(cherry picked from commit f657b54281)
This commit is contained in:
Jason Lowe 2016-01-12 23:56:23 +00:00
parent 2605e78e44
commit 0af01092b6
2 changed files with 44 additions and 28 deletions

View File

@ -171,6 +171,9 @@ Release 2.8.0 - UNRELEASED
MAPREDUCE-6394. Speed up Task processing loop in HsTasksBlock#render() MAPREDUCE-6394. Speed up Task processing loop in HsTasksBlock#render()
(Ray Chiang via jlowe) (Ray Chiang via jlowe)
MAPREDUCE-6473. Job submission can take a long time during Cluster
initialization (Kuhu Shukla via jlowe)
BUG FIXES BUG FIXES
MAPREDUCE-6314. TestPipeApplication fails on trunk. MAPREDUCE-6314. TestPipeApplication fails on trunk.

View File

@ -66,7 +66,23 @@ public class Cluster {
private static ServiceLoader<ClientProtocolProvider> frameworkLoader = private static ServiceLoader<ClientProtocolProvider> frameworkLoader =
ServiceLoader.load(ClientProtocolProvider.class); ServiceLoader.load(ClientProtocolProvider.class);
private volatile List<ClientProtocolProvider> providerList = null;
private void initProviderList() {
if (providerList == null) {
synchronized (frameworkLoader) {
if (providerList == null) {
List<ClientProtocolProvider> localProviderList =
new ArrayList<ClientProtocolProvider>();
for (ClientProtocolProvider provider : frameworkLoader) {
localProviderList.add(provider);
}
providerList = localProviderList;
}
}
}
}
static { static {
ConfigUtil.loadResources(); ConfigUtil.loadResources();
} }
@ -85,34 +101,31 @@ public class Cluster {
private void initialize(InetSocketAddress jobTrackAddr, Configuration conf) private void initialize(InetSocketAddress jobTrackAddr, Configuration conf)
throws IOException { throws IOException {
synchronized (frameworkLoader) { initProviderList();
for (ClientProtocolProvider provider : frameworkLoader) { for (ClientProtocolProvider provider : providerList) {
LOG.debug("Trying ClientProtocolProvider : " LOG.debug("Trying ClientProtocolProvider : "
+ provider.getClass().getName()); + provider.getClass().getName());
ClientProtocol clientProtocol = null; ClientProtocol clientProtocol = null;
try { try {
if (jobTrackAddr == null) { if (jobTrackAddr == null) {
clientProtocol = provider.create(conf); clientProtocol = provider.create(conf);
} else { } else {
clientProtocol = provider.create(jobTrackAddr, conf); clientProtocol = provider.create(jobTrackAddr, conf);
}
if (clientProtocol != null) {
clientProtocolProvider = provider;
client = clientProtocol;
LOG.debug("Picked " + provider.getClass().getName()
+ " as the ClientProtocolProvider");
break;
}
else {
LOG.debug("Cannot pick " + provider.getClass().getName()
+ " as the ClientProtocolProvider - returned null protocol");
}
}
catch (Exception e) {
LOG.info("Failed to use " + provider.getClass().getName()
+ " due to error: ", e);
} }
if (clientProtocol != null) {
clientProtocolProvider = provider;
client = clientProtocol;
LOG.debug("Picked " + provider.getClass().getName()
+ " as the ClientProtocolProvider");
break;
} else {
LOG.debug("Cannot pick " + provider.getClass().getName()
+ " as the ClientProtocolProvider - returned null protocol");
}
} catch (Exception e) {
LOG.info("Failed to use " + provider.getClass().getName()
+ " due to error: ", e);
} }
} }