azkaban.soloserver.AzkabanSingleServer.java Source code

Java tutorial

Introduction

Here is the source code for azkaban.soloserver.AzkabanSingleServer.java

Source

/*
 * Copyright 2012 LinkedIn Corp.
 *
 * 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 azkaban.soloserver;

import static azkaban.ServiceProvider.SERVICE_PROVIDER;

import azkaban.AzkabanCommonModule;
import azkaban.database.AzkabanDatabaseSetup;
import azkaban.database.AzkabanDatabaseUpdater;
import azkaban.execapp.AzkabanExecServerModule;
import azkaban.execapp.AzkabanExecutorServer;
import azkaban.server.AzkabanServer;
import azkaban.utils.Props;
import azkaban.webapp.AzkabanWebServer;
import azkaban.webapp.AzkabanWebServerModule;
import com.google.inject.Guice;
import com.google.inject.Injector;
import java.io.File;
import java.io.IOException;
import java.security.Permission;
import java.security.Policy;
import java.security.ProtectionDomain;
import javax.inject.Inject;
import org.apache.commons.io.FileUtils;
import org.apache.log4j.Logger;

public class AzkabanSingleServer {

    private static final Logger log = Logger.getLogger(AzkabanWebServer.class);

    private final AzkabanWebServer webServer;
    private final AzkabanExecutorServer executor;

    @Inject
    public AzkabanSingleServer(final AzkabanWebServer webServer, final AzkabanExecutorServer executor) {
        this.webServer = webServer;
        this.executor = executor;
    }

    public static void main(String[] args) throws Exception {
        log.info("Starting Azkaban Server");

        if (System.getSecurityManager() == null) {
            Policy.setPolicy(new Policy() {
                @Override
                public boolean implies(final ProtectionDomain domain, final Permission permission) {
                    return true; // allow all
                }
            });
            System.setSecurityManager(new SecurityManager());
        }

        if (args.length == 0) {
            args = prepareDefaultConf();
        }

        final Props props = AzkabanServer.loadProps(args);
        if (props == null) {
            log.error("Properties not found. Need it to connect to the db.");
            log.error("Exiting...");
            return;
        }

        if (props.getBoolean(AzkabanDatabaseSetup.DATABASE_CHECK_VERSION, true)) {
            final boolean updateDB = props.getBoolean(AzkabanDatabaseSetup.DATABASE_AUTO_UPDATE_TABLES, true);
            final String scriptDir = props.getString(AzkabanDatabaseSetup.DATABASE_SQL_SCRIPT_DIR, "sql");
            AzkabanDatabaseUpdater.runDatabaseUpdater(props, scriptDir, updateDB);
        }

        /* Initialize Guice Injector */
        final Injector injector = Guice.createInjector(new AzkabanCommonModule(props), new AzkabanWebServerModule(),
                new AzkabanExecServerModule());
        SERVICE_PROVIDER.setInjector(injector);

        /* Launch server */
        injector.getInstance(AzkabanSingleServer.class).launch();
    }

    /**
     * To enable "run out of the box for testing".
     */
    private static String[] prepareDefaultConf() throws IOException {
        final File templateFolder = new File("test/local-conf-templates");
        final File localConfFolder = new File("local/conf");
        if (!localConfFolder.exists()) {
            FileUtils.copyDirectory(templateFolder, localConfFolder.getParentFile());
            log.info("Copied local conf templates from " + templateFolder.getAbsolutePath());
        }
        log.info("Using conf at " + localConfFolder.getAbsolutePath());
        return new String[] { "-conf", "local/conf" };
    }

    private void launch() throws Exception {
        // exec server first so that it's ready to accept calls by web server when web initializes
        AzkabanExecutorServer.launch(this.executor);
        log.info("Azkaban Exec Server started...");

        AzkabanWebServer.launch(this.webServer);
        log.info("Azkaban Web Server started...");
    }
}