Search in sources :

Example 6 with ClusteringAgent

use of org.apache.axis2.clustering.ClusteringAgent in project wso2-synapse by wso2.

the class SampleAxis2ServerManager method start.

public void start(String[] args) throws Exception {
    String repoLocation = null;
    String confLocation = null;
    CommandLineOptionParser optionsParser = new CommandLineOptionParser(args);
    List invalidOptionsList = optionsParser.getInvalidOptions(new OptionsValidator() {

        public boolean isInvalid(CommandLineOption option) {
            String optionType = option.getOptionType();
            return !("repo".equalsIgnoreCase(optionType) || "conf".equalsIgnoreCase(optionType));
        }
    });
    if ((invalidOptionsList.size() > 0) || (args.length > 4)) {
        printUsage();
    }
    Map optionsMap = optionsParser.getAllOptions();
    CommandLineOption repoOption = (CommandLineOption) optionsMap.get("repo");
    CommandLineOption confOption = (CommandLineOption) optionsMap.get("conf");
    log.info("[SimpleAxisServer] Starting");
    if (repoOption != null) {
        repoLocation = repoOption.getOptionValue();
        System.out.println("[SimpleAxisServer] Using the Axis2 Repository : " + new File(repoLocation).getAbsolutePath());
    }
    if (confOption != null) {
        confLocation = confOption.getOptionValue();
        System.out.println("[SimpleAxisServer] Using the Axis2 Configuration File : " + new File(confLocation).getAbsolutePath());
    }
    try {
        configctx = ConfigurationContextFactory.createConfigurationContextFromFileSystem(repoLocation, confLocation);
        configurePort(configctx);
        // Need to initialize the cluster manager at last since we are changing the servers
        // HTTP/S ports above. In the axis2.xml file, we need to set the "AvoidInitiation" param
        // to "true"
        ClusteringAgent clusteringAgent = configctx.getAxisConfiguration().getClusteringAgent();
        if (clusteringAgent != null) {
            clusteringAgent.setConfigurationContext(configctx);
            clusteringAgent.init();
        }
        // Finally start the transport listeners
        listenerManager = new ListenerManager();
        listenerManager.init(configctx);
        listenerManager.start();
        log.info("[SimpleAxisServer] Started");
    } catch (Throwable t) {
        log.fatal("[SimpleAxisServer] Shutting down. Error starting SimpleAxisServer", t);
        // must stop application
        System.exit(1);
    }
}
Also used : OptionsValidator(org.apache.axis2.util.OptionsValidator) CommandLineOption(org.apache.axis2.util.CommandLineOption) List(java.util.List) ClusteringAgent(org.apache.axis2.clustering.ClusteringAgent) Map(java.util.Map) File(java.io.File) CommandLineOptionParser(org.apache.axis2.util.CommandLineOptionParser) ListenerManager(org.apache.axis2.engine.ListenerManager)

Aggregations

ClusteringAgent (org.apache.axis2.clustering.ClusteringAgent)6 ConfigurationContext (org.apache.axis2.context.ConfigurationContext)2 SynapseException (org.apache.synapse.SynapseException)2 Axis2SynapseEnvironment (org.apache.synapse.core.axis2.Axis2SynapseEnvironment)2 HazelcastInstance (com.hazelcast.core.HazelcastInstance)1 File (java.io.File)1 IOException (java.io.IOException)1 List (java.util.List)1 Map (java.util.Map)1 ParseException (javax.mail.internet.ParseException)1 AxisFault (org.apache.axis2.AxisFault)1 DefaultGroupManagementAgent (org.apache.axis2.clustering.management.DefaultGroupManagementAgent)1 ListenerManager (org.apache.axis2.engine.ListenerManager)1 CommandLineOption (org.apache.axis2.util.CommandLineOption)1 CommandLineOptionParser (org.apache.axis2.util.CommandLineOptionParser)1 OptionsValidator (org.apache.axis2.util.OptionsValidator)1 FileNotFolderException (org.apache.commons.vfs2.FileNotFolderException)1 FileNotFoundException (org.apache.commons.vfs2.FileNotFoundException)1 FileObject (org.apache.commons.vfs2.FileObject)1 FileSystemException (org.apache.commons.vfs2.FileSystemException)1