Github user kishorvpatil commented on a diff in the pull request:

    https://github.com/apache/storm/pull/2878#discussion_r225502712
  
    --- Diff: storm-core/src/jvm/org/apache/storm/command/KillTopology.java ---
    @@ -25,21 +25,49 @@
     
         public static void main(String[] args) throws Exception {
             Map<String, Object> cl = CLI.opt("w", "wait", null, CLI.AS_INT)
    +                                    .boolOpt("i", "ignore-errors")
                                         .arg("TOPO", CLI.INTO_LIST)
                                         .parse(args);
    +
    +        @SuppressWarnings("unchecked")
             final List<String> names = (List<String>) cl.get("TOPO");
    +
    +        // wait seconds for topology to shut down
             Integer wait = (Integer) cl.get("w");
     
    +        // if '-i' set, we'll try to kill every topology listed, even if 
an error occurs
    +        Boolean continueOnError = (Boolean) cl.get("i");
    +
             final KillOptions opts = new KillOptions();
             if (wait != null) {
                 opts.set_wait_secs(wait);
             }
    +
             NimbusClient.withConfiguredClient(new NimbusClient.WithNimbus() {
                 @Override
                 public void run(Nimbus.Iface nimbus) throws Exception {
    +                int errorCount = 0;
                     for (String name : names) {
    -                    nimbus.killTopologyWithOpts(name, opts);
    -                    LOG.info("Killed topology: {}", name);
    +                    try {
    +                        nimbus.killTopologyWithOpts(name, opts);
    +                        LOG.info("Killed topology: {}", name);
    +                    } catch (Exception e) {
    +                        errorCount += 1;
    +                        if (!continueOnError) {
    +                            throw e;
    +                        } else {
    +                            LOG.info(
    +                                    "Caught error killing topology '{}'; 
continuing as -i was passed. Exception: {}",
    --- End diff --
    
    I would use LOG.error and let all error detais/stracktrace be printed 
instead of providing just Exception class name.


---

Reply via email to