All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.ow2.jonas.ant.cluster.DiscoveryCluster Maven / Gradle / Ivy

/**
 * JOnAS: Java(TM) Open Application Server
 * Copyright (C) 2005 Bull S.A.
 * Contact: [email protected]
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307
 * USA
 *
 * Initial developer: Benoit Pelletier
 * --------------------------------------------------------------------------
 * $Id: DiscoveryCluster.java 18416 2009-08-26 20:38:20Z eyindanga $
 * --------------------------------------------------------------------------
 */

package org.ow2.jonas.ant.cluster;

import java.io.File;
import java.util.Iterator;

import org.apache.tools.ant.BuildException;
import org.apache.tools.ant.Task;
import org.ow2.jonas.ant.jonasbase.BaseTaskItf;
import org.ow2.jonas.ant.jonasbase.Discovery;


/**
 * Define DiscoveryCluster task
 * @author Benoit Pelletier
 */
public class DiscoveryCluster extends ClusterTasks {

    /**
     * Info for the logger
     */
    private static final String INFO = "[DiscoveryCluster] ";


    /**
     * greeting ports range
     */
    private String[] greetingPortRange = null;

    /**
     * source ports range
     */
    private String[] sourcePortRange = null;

    /**
     * multicast port
     */
    private String mcastPort = null;

    /**
     * multicast addr
     */
    private String mcastAddr = null;

    /**
     * ind of master node
     */
    private int masterNode = -1;

    /**
     * jonas_root
     */
    private String jonasRoot = null;

    /**
     * domain name
     */
    private String domainName = null;

    /**
     * protocol
     */
    private String protocol = null;

    /**
     * carol ports range
     */
    private String[] carolPortRange = null;

    /**
     * domain desc
     */
    private String domainDesc = null;

    /**
     * cluster name
     */
    private String clusterName = null;

    /**
     * cluster desc
     */
    private String clusterDesc = null;

    /**
     * nodes name
     */
    private String clusterNodesName = null;

    /**
     * cluster daemon name
     */
    private String cdName = null;

    /**
     * cluster daemon protocol
     */
    private String cdProtocol = null;

    /**
     * cluster daemon port
     */
    private String cdPort = null;


    /**
     * Default constructor
     */
    public DiscoveryCluster() {
        super();
    }

    /**
     * Set master node
     * @param masterNode inf of the master node
     */
    public void setMasterNode(final int masterNode) {
        this.masterNode = masterNode;
    }

    /**
     * Set mcastPort
     * @param mcastPort multicast port to set
     */
    public void setMcastPort(final String mcastPort) {
        this.mcastPort = mcastPort;
    }

    /**
     * Set mcastAddr
     * @param mcastAddr multicast address to set
     */
    public void setMcastAddr(final String mcastAddr) {
        this.mcastAddr = mcastAddr;
    }

    /**
     * Set greeting ports range
     * @param portRange ports range
     */
    public void setGreetingPortRange(final String portRange) {
        this.greetingPortRange = portRange.split(",");

    }

    /**
     * Set source ports range
     * @param portRange ports range
     */
    public void setSourcePortRange(final String portRange) {
        this.sourcePortRange = portRange.split(",");

    }

    /**
     * Set domainName
     * @param domainName domain name
     */
    public void setDomainName(final String domainName) {
        this.domainName = domainName;
    }

    /**
     * Set domainDesc
     * @param domainDesc domain desc
     */
    public void setDomainDesc(final String domainDesc) {
        this.domainDesc = domainDesc;
    }

    /**
     * Set clusterName
     * @param clusterName cluster name
     */
    public void setClusterName(final String clusterName) {
        this.clusterName = clusterName;
    }

    /**
     * Set clusterDesc
     * @param clusterDesc cluster desc
     */
    public void setClusterDesc(final String clusterDesc) {
        this.clusterDesc = clusterDesc;
    }

    /**
     * Generates the discovery tasks for each JOnAS's instances
     */
    @Override
    public void generatesTasks() {

        int portInd = 0;

        for (int i = getDestDirSuffixIndFirst(); i <= getDestDirSuffixIndLast(); i++) {

            String destDir = getDestDir(getDestDirPrefix(), i);
            log(INFO + "tasks generation for " + destDir);
            // creation of the Discovery tasks
            Discovery discovery = new Discovery();

            if (i == masterNode) {
                discovery.setJonasRoot(jonasRoot);
                discovery.setSourcePort(sourcePortRange[portInd]);
                discovery.setDomainDesc(domainDesc);
                /**
                 * FIXME this line will be necessary until the bind_addr problem of JGroups is fixed.
                 * an ip address should be passed on JOnAS starting, that will be used by JGroups channel to avoid static discovery.
                 */
                //discovery.setDomainCluster(clusterName, clusterDesc, clusterNodesName, getWebInstNb() + getEjbInstNb(), protocol, carolPortRange, cdName, getCdUrl());
            }
            discovery.setGreetingPort(greetingPortRange[portInd]);
            discovery.setMcastPort(mcastPort);
            discovery.setMcastAddr(mcastAddr);

            // set destDir for each task
            for (Iterator it = discovery.getTasks().iterator(); it.hasNext();) {
                BaseTaskItf task = (BaseTaskItf) it.next();
                task.setDestDir(new File(destDir));
            }

            addTasks(discovery);

            portInd++;

        }
    }

    /**
     * set the name prefix for the cluster nodes
     * @param clusterNodesName prefix of the nodes names in the cluster
     */
    public void setClusterNodesName(final String clusterNodesName) {
        this.clusterNodesName = clusterNodesName;
    }

    /**
     * Set the protocol used by the server nodes
     * @param protocol protocol
     */
    public void setProtocol(final String protocol) {
        this.protocol = protocol;
    }

    /**
     * Set the name used by the cluster daemon
     * @param cdName cdName
     */
    public void setCdName(final String cdName) {
        this.cdName = cdName;
    }

    /**
     * Set the protocol used by the cluster daemon
     * @param cdProtocol cdProtocol
     */
    public void setCdProtocol(final String cdProtocol) {
        this.cdProtocol = cdProtocol;
    }

    /**
     * Set the port used by the cluster daemon
     * @param cdPort cdPort
     */
    public void setCdPort(final String cdPort) {
        this.cdPort = cdPort;
    }

    /**
     * Build the cluster daemon JRM remote url
     * @return url
     */
    public String getCdUrl(){
        String scheme;
        if(cdProtocol.equals("jrmp") || cdProtocol.equals("irmi")) {
            scheme = "rmi";
        } else if(cdProtocol.equals("iiop")) {
            scheme = "iiop";
        } else {
            throw new BuildException(INFO + "Unknown protocol for cluster daemon: " + cdProtocol);
        }
        String url = "service:jmx:" + scheme + "://localhost/jndi/"
            + scheme + "://localhost:" + cdPort + "/" + cdProtocol + "connector_" + cdName;
        return url;
    }

    /**
     * set the carol port range
     * @param carolPortRange carol port range
     */
    public void setCarolPortRange(final String carolPortRange) {
        this.carolPortRange = carolPortRange.split(",");
    }

    /**
     * Set JONAS ROOT
     * @param jonasRoot directory
     */
    public void setJonasRoot(final String jonasRoot) {
        this.jonasRoot = jonasRoot;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy