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:
parent
2605e78e44
commit
0af01092b6
|
@ -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.
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue