Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
 /*
  * (C) 2007-2012 Alibaba Group Holding Limited.
  * 
  * 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.
 * Authors:
 *   wuhua <wq163@163.com> , boyan <killme2008@gmail.com>
 */
package com.taobao.metamorphosis.tools.shell;
 �ر�һ��topic��ָ������
 usage:
      ClosePartitionsTool -topic xxtopic -start 2 -end 5
      ClosePartitionsTool -topic xxtopic -start 2 -end 5 -host 10.2.2.3
      ClosePartitionsTool -topic xxtopic -start 2 -end 5 -port 9999
      ClosePartitionsTool -topic xxtopic -start 2 -end 5 -host 10.2.2.3 -port 9999
 

Author(s):
�޻�
Since:
2011-8-23 ����3:42:38
public class ClosePartitionsTool extends ShellTool {
    public ClosePartitionsTool(PrintStream out) {
        super(out);
    }
    public ClosePartitionsTool(PrintWriter writer) {
        super(writer);
    }
    public static void main(String[] argsthrows Exception {
        new ClosePartitionsTool(.).doMain(args);
    }
    @Override
    public void doMain(String[] argsthrows Exception {
        CommandLine commandLine = this.getCommandLine(args);
        String host = commandLine.getOptionValue("host""127.0.0.1");
        int port = Integer.parseInt(commandLine.getOptionValue("port""9999"));
        String topic = commandLine.getOptionValue("topic");
        int start = Integer.parseInt(commandLine.getOptionValue("start"));
        int end = Integer.parseInt(commandLine.getOptionValue("end"));
        JMXClient jmxClient = JMXClient.getJMXClient(hostport);
        this.println("connected to " + jmxClient.getAddressAsString());
        ObjectInstance metaConfigInstance = jmxClient.queryMBeanForOne();
        if (metaConfigInstance != null) {
            jmxClient.invoke(metaConfigInstance.getObjectName(), "closePartitions"new Object[] { topicstartend },
                new String[] { "java.lang.String""int""int" });
            jmxClient.close();
            this.println("invoke " + metaConfigInstance.getClassName() + "#closePartitions success");
        }
        else {
            this.println("û���ҵ� " + );
        }
    }
    private CommandLine getCommandLine(String[] args) {
        Option topicOption = new Option("topic"true"topic");
        topicOption.setRequired(true);
        Option startOption = new Option("start"true"start partition num");
        startOption.setRequired(true);
        Option endOption = new Option("end"true"end partition num");
        endOption.setRequired(true);
        return CommandLineUtils.parseCmdLine(argsnew Options().addOption(topicOption).addOption(startOption)
            .addOption(endOption).addOption("host"true"host").addOption("port"true"port"));
    }
New to GrepCode? Check out our FAQ X