// Launch Hadoop "master" (NN and JT)
// deal with user packages and autoshutdown with extra runurls
String hadoopInstallRunUrl = clusterSpec.getConfiguration().getString(
"whirr.hadoop-install-runurl", "apache/hadoop/install");
Payload nnjtBootScript = newStringPayload(runUrls(clusterSpec.getRunUrlBase(),
String.format("util/configure-hostnames -c %s", clusterSpec.getProvider()),
"sun/java/install",
String.format("%s nn,jt -c %s", hadoopInstallRunUrl,
clusterSpec.getProvider())));
LOG.info("Configuring template");
TemplateBuilder masterTemplateBuilder = computeService.templateBuilder()
.options(runScript(nnjtBootScript)
.installPrivateKey(clusterSpec.getPrivateKey())
.authorizePublicKey(clusterSpec.getPublicKey()));
TemplateBuilderStrategy strategy = new HadoopTemplateBuilderStrategy();
strategy.configureTemplateBuilder(clusterSpec, masterTemplateBuilder);
Template masterTemplate = masterTemplateBuilder.build();
InstanceTemplate instanceTemplate = clusterSpec.getInstanceTemplate(MASTER_ROLE);
checkNotNull(instanceTemplate);
checkArgument(instanceTemplate.getNumberOfInstances() == 1);
Set<? extends NodeMetadata> nodes;
try {
LOG.info("Starting master node");
nodes = computeService.runNodesWithTag(
clusterSpec.getClusterName(), 1, masterTemplate);
LOG.info("Master node started: {}", nodes);
} catch (RunNodesException e) {
// TODO: can we do better here (retry?)
throw new IOException(e);
}
NodeMetadata node = Iterables.getOnlyElement(nodes);
InetAddress namenodePublicAddress = InetAddress.getByName(Iterables.get(node.getPublicAddresses(),0));
InetAddress jobtrackerPublicAddress = InetAddress.getByName(Iterables.get(node.getPublicAddresses(),0));
LOG.info("Authorizing firewall");
FirewallSettings.authorizeIngress(computeServiceContext, node, clusterSpec,
WEB_PORT);
FirewallSettings.authorizeIngress(computeServiceContext, node, clusterSpec,
NAMENODE_WEB_UI_PORT);
FirewallSettings.authorizeIngress(computeServiceContext, node, clusterSpec,
JOBTRACKER_WEB_UI_PORT);
FirewallSettings.authorizeIngress(computeServiceContext, node, clusterSpec,
namenodePublicAddress.getHostAddress(), NAMENODE_PORT);
FirewallSettings.authorizeIngress(computeServiceContext, node, clusterSpec,
namenodePublicAddress.getHostAddress(), JOBTRACKER_PORT);
if (!namenodePublicAddress.equals(jobtrackerPublicAddress)) {
FirewallSettings.authorizeIngress(computeServiceContext, node, clusterSpec,
jobtrackerPublicAddress.getHostAddress(), NAMENODE_PORT);
FirewallSettings.authorizeIngress(computeServiceContext, node, clusterSpec,
jobtrackerPublicAddress.getHostAddress(), JOBTRACKER_PORT);
}
// Launch slaves (DN and TT)
Payload slaveBootScript = newStringPayload(runUrls(clusterSpec.getRunUrlBase(),
String.format("util/configure-hostnames -c %s", clusterSpec.getProvider()),
"sun/java/install",
String.format("%s dn,tt -n %s -j %s -c %s",
hadoopInstallRunUrl,
namenodePublicAddress.getHostName(),