/* * Copyright 2008-2012 Xebia and the original author or authors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package fr.xebia.workshop.bigdata; import static com.google.common.base.Preconditions.checkState; import java.io.InputStream; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.TimeUnit; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import com.amazonaws.auth.AWSCredentials; import com.amazonaws.services.ec2.AmazonEC2; import com.amazonaws.services.ec2.AmazonEC2Client; import com.amazonaws.services.route53.AmazonRoute53; import com.amazonaws.services.route53.AmazonRoute53Client; import fr.xebia.cloud.amazon.aws.tools.AmazonAwsUtils; public class WorkshopInfrastructureCreator { private static final Logger logger = LoggerFactory .getLogger(WorkshopInfrastructureCreator.class); public static void main(String args[]) { AWSCredentials awsCredentials = AmazonAwsUtils.loadAwsCredentials(); AmazonEC2 ec2 = new AmazonEC2Client(awsCredentials); ec2.setEndpoint("ec2.eu-west-1.amazonaws.com"); AmazonRoute53 route53 = new AmazonRoute53Client(awsCredentials); WorkshopInfrastructure workshopInfrastructure = new WorkshopInfrastructure() .withTeamIdentifiers("1" /* ,"2" * , "3", "4", "5", "6", "7", "8", * "9", "10", "11" */) .withAwsAccessKeyId(awsCredentials.getAWSAccessKeyId()) .withAwsSecretKey(awsCredentials.getAWSSecretKey()) .withKeyPairName("xte-flume"); // checks for Key in classpath: prevents launching instances if not // present checkKeyFile(workshopInfrastructure); AmazonAwsUtils.terminateInstancesByWorkshop("flume-hadoop", ec2); ExecutorService executor = Executors.newFixedThreadPool(3); //executor.execute(new CreateTomcatServers(ec2, route53, // workshopInfrastructure)); executor.execute(new CreateHadoopMasterNode(ec2, route53, workshopInfrastructure)); executor.execute(new CreateHadoopSlaveNode(ec2, route53, workshopInfrastructure)); executor.shutdown(); try { executor.awaitTermination(10, TimeUnit.MINUTES); executor.shutdownNow(); } catch (Exception e) { logger.error(e.getMessage()); } logger.info("Workshop infrastructure created"); } protected static void checkKeyFile(final WorkshopInfrastructure infra) { InputStream keyFile = Thread.currentThread().getContextClassLoader() .getResourceAsStream(infra.getKeyPairName() + ".pem"); checkState(keyFile != null, "File '" + infra.getKeyPairName() + ".pem' NOT found in the classpath"); } }