Package org.jgroups.tests

Source Code of org.jgroups.tests.McastSenderTest

// $Id: McastSenderTest.java,v 1.8 2005/09/12 14:03:19 belaban Exp $

package org.jgroups.tests;


import java.io.DataInputStream;
import java.net.*;
import java.util.ArrayList;
import java.util.Enumeration;


/**
Tests IP multicast. Start one or more instances of McastReceiverTest which listen for IP mcast packets
and then start McastSenderTest, which sends IP mcast packets (all have to have the same IPMCAST address and port).
A TTL of 0 for the McastSenderTest means that packets will only be sent to receivers on the same host. If TTL > 0,
other hosts will receive the packets too. Since many routers are dropping IPMCAST traffic, this is a good way to
test whether IPMCAST works between different subnets.
@see McastReceiverTest
@author Bela Ban
@version $Revision: 1.8 $
*/
public class McastSenderTest {

    public static void main(String args[]) {
        MulticastSocket sock=null;
        ArrayList sockets=null;
        InetAddress mcast_addr=null, bind_addr=null;
        DatagramPacket packet;
        byte[] buf=new byte[0];
        String tmp;
        int ttl=32;
        String line;
        DataInputStream in;
        AckReceiver ack_receiver=null;
        int port=5555;
        boolean send_on_all_interfaces=false;


        try {
            for(int i=0; i < args.length; i++) {
                tmp=args[i];
                if("-help".equals(tmp)) {
                    help();
                    return;
                }
                if("-bind_addr".equals(tmp)) {
                    bind_addr=InetAddress.getByName(args[++i]);
                    continue;
                }
                if("-mcast_addr".equals(tmp)) {
                    mcast_addr=InetAddress.getByName(args[++i]);
                    continue;
                }
                if("-ttl".equals(tmp)) {
                    ttl=Integer.parseInt(args[++i]);
                    continue;
                }
                if("-port".equals(tmp)) {
                    port=Integer.parseInt(args[++i]);
                    continue;
                }
                if("-send_on_all_interfaces".equals(args[i])) {
                    send_on_all_interfaces=true;
                    continue;
                }
                help();
                return;
            }
            if(mcast_addr == null)
                mcast_addr=InetAddress.getByName("224.0.0.150");
        }
        catch(Exception ex) {
            System.err.println(ex);
            return;
        }


        try {
            if(send_on_all_interfaces) {
                sockets=new ArrayList(10);
                NetworkInterface intf;
                MulticastSocket s;

                for(Enumeration en=NetworkInterface.getNetworkInterfaces(); en.hasMoreElements();) {
                    intf=(NetworkInterface)en.nextElement();
                    s=new MulticastSocket();
                    sockets.add(s);
                    s.setTimeToLive(ttl);
                    s.setNetworkInterface(intf);
                    System.out.println("Socket=" + s.getLocalAddress() + ':' + s.getLocalPort() +
                            ", ttl=" + s.getTimeToLive() + ", bind interface=" + s.getInterface());
                    ack_receiver=new AckReceiver(s);
                    ack_receiver.start();
                }
            }
            else {
                sock=new MulticastSocket();
                sock.setTimeToLive(ttl);
                if(bind_addr != null)
                    sock.setInterface(bind_addr);

                System.out.println("Socket=" + sock.getLocalAddress() + ':' + sock.getLocalPort() +
                        ", ttl=" + sock.getTimeToLive() + ", bind interface=" + sock.getInterface());
                ack_receiver=new AckReceiver(sock);
                ack_receiver.start();
            }


            in=new DataInputStream(System.in);
            while(true) {
                System.out.print("> ");
                line=in.readLine();
                if(line.startsWith("quit") || line.startsWith("exit")) {
                    if(ack_receiver != null)
                        ack_receiver.stop();
                    break;
                }
                buf=line.getBytes();
                packet=new DatagramPacket(buf, buf.length, mcast_addr, port);
                if(sock != null) {
                    sock.send(packet);
                }
                else {
                    for(int i=0; i < sockets.size(); i++) {
                        MulticastSocket s=(MulticastSocket)sockets.get(i);
                        s.send(packet);
                    }
                }
            }
        }
        catch(Exception e) {
            System.err.println(e);
        }

    }


    static void help() {
        System.out.println("McastSenderTest [-bind_addr <bind address>] [-help] [-mcast_addr <multicast address>] " +
                "[-port <multicast port that receivers are listening on>] [-ttl <time to live for mcast packets>] " +
                "[-send_on_all_interfaces]");
    }


    private static class AckReceiver implements Runnable {
        DatagramSocket sock;
        DatagramPacket packet;
        byte[] buf;
        Thread t=null;

        AckReceiver(DatagramSocket sock) {
            this.sock=sock;
        }

        public void run() {
            while(t != null) {
                try {
                    buf=new byte[256];
                    packet=new DatagramPacket(buf, buf.length);
                    sock.receive(packet);
                    System.out.println("<< Received response from " +
                                       packet.getAddress().getHostAddress() + ':' +
                                       packet.getPort() + ": " + new String(packet.getData(), 0, packet.getLength()));
                }
                catch(Exception e) {
                    System.err.println(e);
                    break;
                }
            }
            t=null;
        }

        void start() {
            t=new Thread(this, "McastSenderTest.AckReceiver thread");
            t.start();
        }

        void stop() {
            if(t != null && t.isAlive()) {
                t=null;
                try {
                    sock.close();
                }
                catch(Exception e) {
                }
            }
        }
    }


}
TOP

Related Classes of org.jgroups.tests.McastSenderTest

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.