All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.elasticsearch.hadoop.yarn.cli.YarnBootstrap Maven / Gradle / Ivy

/*
 * Licensed to Elasticsearch under one or more contributor
 * license agreements. See the NOTICE file distributed with
 * this work for additional information regarding copyright
 * ownership. Elasticsearch licenses this file to you 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 org.elasticsearch.hadoop.yarn.cli;

import java.io.File;
import java.io.IOException;
import java.net.URI;
import java.text.DateFormat;
import java.util.Date;
import java.util.List;

import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.conf.Configured;
import org.apache.hadoop.fs.FileStatus;
import org.apache.hadoop.fs.FileSystem;
import org.apache.hadoop.fs.FileUtil;
import org.apache.hadoop.fs.Path;
import org.apache.hadoop.util.Tool;
import org.apache.hadoop.util.ToolRunner;
import org.apache.hadoop.yarn.api.records.ApplicationId;
import org.apache.hadoop.yarn.api.records.ApplicationReport;
import org.apache.hadoop.yarn.conf.YarnConfiguration;
import org.apache.hadoop.yarn.webapp.util.WebAppUtils;
import org.elasticsearch.hadoop.yarn.cfg.Config;
import org.elasticsearch.hadoop.yarn.client.ClientRpc;
import org.elasticsearch.hadoop.yarn.client.YarnLauncher;
import org.elasticsearch.hadoop.yarn.util.HttpDownloader;
import org.elasticsearch.hadoop.yarn.util.IOUtils;
import org.elasticsearch.hadoop.yarn.util.PropertiesUtils;

/**
 * Starts the client app, allowing defaults to be overridden.
 */
public class YarnBootstrap extends Configured implements Tool {

    private static String HELP = null;
    private Config cfg;

    public static void main(String[] args) throws Exception {
        int status = -1;
        try {
            status = ToolRunner.run(new YarnBootstrap(), args);
        } catch (Exception ex) {
            System.err.println("Abnormal execution:" + ex.getMessage());
            ex.printStackTrace(System.err);
        }
        System.exit(status);
    }

    private void displayHelp(String message) {
        if (message != null) {
            System.out.println(message);
        }
        if (HELP == null) {
            HELP = IOUtils.readFrom(getClass().getResourceAsStream("help.txt"));
        }
        System.out.println(HELP);
    }

    @Override
    public int run(String[] args) throws Exception {
        if (args == null || args.length < 1) {
            displayHelp("No command specified");
            return -1;
        }

        String cmd = args[0];

        cfg = new Config(PropertiesUtils.fromCmdLine(args, 1));

        if ("-download-es".equals(cmd)) {
            downloadEs();
        }
        else if ("-install".equals(cmd)) {
            installEsYarn();
        }
        else if ("-install-es".equals(cmd)) {
            installEs();
        }
        else if ("-help".equals(cmd)) {
            displayHelp(null);
        }
        else if ("-start".equals(cmd)) {
            start();
        }
        else if ("-status".equals(cmd)) {
            status();
        }
        else if ("-stop".equals(cmd)) {
            stop();
        }
        else {
            displayHelp("Unknown command specified " + cmd);
            return -1;
        }

        return 0;
    }

    private void downloadEs() {
        if (cfg.downloadedEs().exists()) {
            System.out.println(String.format("Destination file %s already exists; aborting download...", cfg.downloadedEs()));
            return;
        }
        System.out.println(String.format("Downloading Elasticsearch %s", cfg.downloadEsVersion()));
        new HttpDownloader().downloadES(cfg);
    }

    private void installEsYarn() {
        install(cfg.downloadedEsYarn(), cfg.jarHdfsPath(), getConf());
    }

    private void installEs() {
        install(cfg.downloadedEs(), cfg.esZipHdfsPath(), getConf());
    }

    private void install(File src, String dst, Configuration cfg) {
        Path target = new Path(dst);
        try {
            FileSystem fs = FileSystem.get(URI.create("hdfs:///"), cfg);
            if (fs.exists(target)) {
                fs.delete(target, true);
            }
            FileUtil.copy(src, fs, target, false, cfg);
            FileStatus stats = fs.getFileStatus(target);
            System.out.println(String.format("Uploaded %s to HDFS at %s", src.getAbsolutePath(), stats.getPath()));
        } catch (IOException ex) {
            throw new IllegalStateException(String.format("Cannot upload %s in HDFS at %s", src.getAbsolutePath(), dst), ex);
        }
    }

    private void start() {
        ClientRpc client = new ClientRpc(getConf());
        ApplicationId id = null;
        ApplicationReport report = null;

        try {
            YarnLauncher launcher = new YarnLauncher(client, cfg);
            id = launcher.run();
            report = client.getReport(id);
        } finally {
            client.close();
        }

        System.out.println(String.format("Launched a %d %s Elasticsearch-YARN cluster [%s@%s] at %tc",
                cfg.containersToAllocate(), (cfg.containersToAllocate() > 1 ? "nodes" : "node"), id, report.getTrackingUrl(), report.getStartTime()));
    }

    private void stop() {
        ClientRpc client = new ClientRpc(getConf());
        client.start();
        try {
            List esApps = client.listEsClustersAlive();
            for (ApplicationReport report : esApps) {
                System.out.println(String.format("Stopping Elasticsearch-YARN Cluster with id %s", report.getApplicationId()));
            }
            List apps = client.killEsApps();
            for (ApplicationReport report : apps) {
                System.out.println(String.format("Stopped Elasticsearch-YARN Cluster with id %s", report.getApplicationId()));
            }
        } finally {
            client.close();
        }
    }

    private void status() {
        ClientRpc client = new ClientRpc(getConf());
        client.start();
        List esApps = null;
        try {
            esApps = client.listEsClusters();
        } finally {
            client.close();
        }
        System.out.println(buildStatusReport(esApps));
    }

    private String buildStatusReport(List esApps) {
        if (esApps.isEmpty()) {
            return String.format("No Elasticsearch YARN clusters found at %s, webapp at %s",
                    getConf().get(YarnConfiguration.RM_ADDRESS), WebAppUtils.getRMWebAppURLWithoutScheme(getConf()));
        }

        String columnSeparator = "  ";
        StringBuilder sb = new StringBuilder();
        // header
        sb.append("Id                            ");
        sb.append(columnSeparator);
        sb.append("State     ");
        sb.append(columnSeparator);
        sb.append("Status   ");
        sb.append(columnSeparator);
        sb.append("Start Time       ");
        sb.append(columnSeparator);
        sb.append("Finish Time      ");
        sb.append(columnSeparator);
        sb.append("Tracking URL");
        sb.append("\n");

        DateFormat dateFormat = DateFormat.getDateTimeInstance(DateFormat.SHORT, DateFormat.SHORT);

        for (ApplicationReport appReport : esApps) {
            sb.append(appReport.getApplicationId());
            sb.append(columnSeparator);
            sb.append(box(appReport.getYarnApplicationState().toString(), 10));
            sb.append(columnSeparator);
            sb.append(box(appReport.getFinalApplicationStatus().toString(), 9));
            sb.append(columnSeparator);
            long date = appReport.getStartTime();
            sb.append(date == 0 ? "N/A              " : box(dateFormat.format(new Date(date)), 17));
            sb.append(columnSeparator);
            date = appReport.getFinishTime();
            sb.append(date == 0 ? "N/A              " : box(dateFormat.format(new Date(date)), 17));
            sb.append(columnSeparator);
            sb.append(appReport.getTrackingUrl());
            sb.append(columnSeparator);
            sb.append("\n");
        }

        return sb.toString();
    }

    // add the string to the box and fill it (with spaces) until it reaches its limit
    private String box(String string, int limit) {
        StringBuilder sb = new StringBuilder(string);
        for (int i = sb.length(); i < limit; i++) {
            sb.append(" ");
        }
        return sb.toString();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy