/*
* 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 com.addthis.hydra;
import java.lang.reflect.Method;
import java.util.Set;
import com.addthis.basis.util.Parameter;
import com.addthis.basis.util.LessStrings;
import com.addthis.codec.config.Configs;
import com.addthis.codec.plugins.PluginMap;
import com.addthis.codec.plugins.PluginRegistry;
import com.addthis.hydra.common.util.CloseTask;
import com.addthis.hydra.util.BundleReporter;
import com.google.common.base.Joiner;
import com.google.common.collect.Sets;
import com.typesafe.config.Config;
import com.typesafe.config.ConfigFactory;
import com.typesafe.config.ConfigObject;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* command-line/jar entry-point to start either hydra or batch.
*/
public class Main {
private static final Logger log = LoggerFactory.getLogger(Main.class);
public static void main(String[] args) {
if (args.length > 0) {
Config globalConfig = ConfigFactory.load();
if (globalConfig.getBoolean("hydra.metrics.enable")) {
try {
BundleReporter bundleReporter = Configs.decodeObject(
BundleReporter.class, globalConfig.getConfig("hydra.metrics.config"));
bundleReporter.start();
Runtime.getRuntime().addShutdownHook(
new Thread(new CloseTask(bundleReporter), "Metrics Bundle Reporter Shutdown Hook"));
} catch (Exception e) {
log.warn("Failed to enable metrics reporter from config", e);
}
}
try {
switch(args[0]) {
case "mss":
String mssRoot = Parameter.value("mss.root", "streams");
String meshyPorts = Parameter.value("mss.mesh.ports", "5000");
String meshyPeers = Parameter.value("mss.mesh.peers", "");
for (String portGroup : LessStrings.splitArray(meshyPorts, ";")) {
log.info("[mss] starting meshy with port group: {}", portGroup);
com.addthis.meshy.Main.main(new String[]{"server", portGroup, mssRoot, meshyPeers});
}
break;
default:
PluginMap executables = PluginRegistry.defaultRegistry().asMap().get("executables");
String name = args[0];
Class clazz = executables.getClass(name);
if (clazz != null) {
boolean showBanner = executables.config().getBoolean("_show-banner");
ConfigObject banners = executables.config().getObject("_banners");
if (showBanner && banners.containsKey(name)) {
String banner = banners.get(name).unwrapped().toString();
log.info(String.format("Starting {}%n{}"), name, banner);
}
Method m = clazz.getDeclaredMethod("main", String[].class);
m.invoke(null, (Object) cutargs(args));
} else {
usage();
}
}
} catch (Exception e) {
log.error("Error starting process.", e);
System.exit(1);
}
} else {
usage();
}
}
private static String[] cutargs(String[] args) {
String[] ns = new String[args.length - 1];
System.arraycopy(args, 1, ns, 0, args.length - 1);
return ns;
}
private static void usage() {
PluginMap pluginMap = PluginRegistry.defaultRegistry().asMap().get("executables");
Set<String> hardCodedOptions = Sets.newHashSet("validate", "mss");
String options = Joiner.on(" | ").join(Sets.union(pluginMap.asBiMap().keySet(), hardCodedOptions));
String usage = "usage: run [ " + options + " ]";
System.out.println(usage);
}
}