Package cluster.queue

Source Code of cluster.queue.ClusterAdminAdd

/*
* JORAM: Java(TM) Open Reliable Asynchronous Messaging
* Copyright (C) 2004 - France Telecom R&D
*
* 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(s): Nicolas Tachker (ScalAgent)
* Contributor(s):
*/
package cluster.queue;

import java.util.Hashtable;
import java.util.Properties;

import org.objectweb.joram.client.jms.Queue;
import org.objectweb.joram.client.jms.admin.AdminHelper;
import org.objectweb.joram.client.jms.admin.AdminModule;
import org.objectweb.joram.client.jms.admin.ClusterQueue;
import org.objectweb.joram.client.jms.admin.User;
import org.objectweb.joram.client.jms.tcp.QueueTcpConnectionFactory;

/**
* Administers three agent servers for the cluster sample.
*/
public class ClusterAdminAdd {

  public static void main(String[] args) throws Exception {
   
    System.out.println();
    System.out.println("Cluster administration Add ...");

    javax.naming.Context jndiCtx = new javax.naming.InitialContext();
   
    Properties prop = new Properties();
    prop.setProperty("period",args[0]);
    prop.setProperty("producThreshold",args[1]);
    prop.setProperty("consumThreshold",args[2]);
    prop.setProperty("autoEvalThreshold",args[3]);
    prop.setProperty("waitAfterClusterReq",args[4]);
    System.out.println("prop = " + prop);

    String sid = args[5];
    int id = new Integer(sid).intValue();
    String host = args[6];
    int port = new Integer(args[7]).intValue();

    AdminModule.connect(host, port, "root", "root", 60);

    Queue queue = Queue.create(
      id,
      null,
      "org.objectweb.joram.mom.dest.ClusterQueue",
      prop);
   
    System.out.println("queue = " + queue);

    User user = User.create("user"+sid, "user"+sid, id);


    javax.jms.QueueConnectionFactory cf =
      QueueTcpConnectionFactory.create("localhost", 16010+id);

    ClusterQueue cluster = (ClusterQueue) jndiCtx.lookup("clusterQueue");

    AdminHelper.setQueueCluster(cluster,queue);

    Hashtable h = cluster.getCluster();
    h.put(sid,queue);

    ClusterQueue clusterQueue = new ClusterQueue(h);
    System.out.println("clusterQueue = " + clusterQueue);

    clusterQueue.setReader(user);
    clusterQueue.setWriter(user);


    jndiCtx.bind("qcf"+sid, cf);
    jndiCtx.rebind("clusterQueue",clusterQueue);
    jndiCtx.bind("queue"+sid, queue);
    jndiCtx.close();

    AdminModule.disconnect();
    System.out.println("Admins closed.");
  }
}
TOP

Related Classes of cluster.queue.ClusterAdminAdd

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.