package com.alibaba.jstorm; import backtype.storm.Config; import backtype.storm.LocalCluster; import backtype.storm.StormSubmitter; import backtype.storm.topology.TopologyBuilder; import com.alibaba.jstorm.ons.consumer.ConsumerSpout; import com.alibaba.jstorm.ons.producer.ProducerBolt; import com.alibaba.jstorm.utils.JStormUtils; import java.util.HashMap; import java.util.Map; public class TestTopology { private static Map conf = new HashMap<Object, Object>(); public static void main(String[] args) throws Exception { if (args.length == 0) { System.err.println("Please input configuration file"); System.exit(-1); } conf = LoadConfig.LoadConf(args[0]); TopologyBuilder builder = setupBuilder(); submitTopology(builder); } private static TopologyBuilder setupBuilder() throws Exception { TopologyBuilder builder = new TopologyBuilder(); int writerParallel = JStormUtils.parseInt(conf.get("topology.producer.parallel"), 1); int spoutParallel = JStormUtils.parseInt(conf.get("topology.consumer.parallel"), 1); builder.setSpout("OnsConsumer", new ConsumerSpout(), spoutParallel); builder.setBolt("OnsProducer", new ProducerBolt(), writerParallel).localFirstGrouping("OnsConsumer"); return builder; } private static void submitTopology(TopologyBuilder builder) { try { if (local_mode(conf)) { LocalCluster cluster = new LocalCluster(); cluster.submitTopology(String.valueOf(conf.get("topology.name")), conf, builder.createTopology()); Thread.sleep(200000); cluster.shutdown(); } else { StormSubmitter.submitTopology(String.valueOf(conf.get("topology.name")), conf, builder.createTopology()); } } catch (Exception e) { e.printStackTrace(); } } public static boolean local_mode(Map conf) { String mode = (String) conf.get(Config.STORM_CLUSTER_MODE); if (mode != null) { if (mode.equals("local")) { return true; } } return false; } }