/* * Copyright (c) 2007, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. * * This code 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 General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions.
*/
publicvoid run() throws Exception { if (isWindows()) {
System.out.println("The test only run on non-Windows OS. Bye."); return;
}
if (!hasIPv6()) {
System.out.println("No IPv6 available. Bye."); return;
}
// We need 2 or more network interfaces to run the test //
List<NetIf> netIfs = new ArrayList<NetIf>(); int index = 1; for (NetworkInterface nic : Collections.list(NetworkInterface.getNetworkInterfaces())) { // we should use only network interfaces with multicast support which are in "up" state if (!nic.isLoopback() && nic.supportsMulticast() && nic.isUp() && !isTestExcludedInterface(nic)) {
NetIf netIf = NetIf.create(nic);
// now determine what (if any) type of addresses are assigned to this interface for (InetAddress addr : Collections.list(nic.getInetAddresses())) { if (addr.isAnyLocalAddress()) continue;
System.out.println(" addr " + addr); if (addr instanceof Inet4Address) {
netIf.ipv4Address(true);
} elseif (addr instanceof Inet6Address) {
netIf.ipv6Address(true);
}
} if (netIf.ipv4Address() || netIf.ipv6Address()) {
netIf.index(index++);
netIfs.add(netIf);
debug("Using: " + nic);
}
} else {
System.out.println("Ignore NetworkInterface nic == " + nic);
}
}
Collections.reverse(netIfs); if (netIfs.size() <= 1) {
System.out.println("Need 2 or more network interfaces to run. Bye."); return;
}
System.out.println("Using PORT: " + PORT);
// We will send packets to one ipv4, and one ipv6 // multicast group using each network interface :- // 224.1.1.1 --| // ff02::1:1 --|--> using network interface #1 // 224.1.2.1 --| // ff02::1:2 --|--> using network interface #2 // and so on. // for (NetIf netIf : netIfs) { int NetIfIndex = netIf.index();
List<InetAddress> groups = new ArrayList<InetAddress>();
debug("Adding " + groups + " groups for " + netIf.nic().getName());
netIf.groups(groups);
// use a separated thread to send to those 2 groups var multicastSender = new MulticastSender(netIf, groups, PORT);
sendersMap.put(netIf, multicastSender); Thread sender = newThread(multicastSender);
sender.setDaemon(true); // we want sender to stop when main thread exits
sender.start();
}
// try to receive on each group, then check if the packet comes // from the expected network interface // byte[] buf = newbyte[1024]; for (NetIf netIf : netIfs) {
NetworkInterface nic = netIf.nic(); for (InetAddress group : netIf.groups()) { try (MulticastSocket mcastsock = new MulticastSocket(PORT)) {
mcastsock.setSoTimeout(5000); // 5 second
DatagramPacket packet = new DatagramPacket(buf, 0, buf.length);
// the interface supports the IP multicast group
debug("Joining " + group + " on " + nic.getName());
mcastsock.joinGroup(new InetSocketAddress(group, PORT), nic);
try {
mcastsock.receive(packet);
debug("received packet on " + packet.getAddress());
} catch (Exception e) { // test failed if any exception thrownew RuntimeException(e);
}
// now check which network interface this packet comes from
NetworkInterface from = NetworkInterface.getByInetAddress(packet.getAddress());
NetworkInterface shouldbe = nic; if (from != null) { if (!from.equals(shouldbe)) {
System.out.println("Packets on group "
+ group + " should come from "
+ shouldbe.getName() + ", but came from "
+ from.getName());
}
}
public MulticastSender(NetIf netIf,
List<InetAddress> groups, int port) { this.netIf = netIf; this.groups = groups; this.port = port;
}
@Override publicvoid close() {
closed = true;
}
publicvoid run() { var nic = netIf.nic(); try (MulticastSocket mcastsock = new MulticastSocket()) {
mcastsock.setNetworkInterface(nic);
List<DatagramPacket> packets = new LinkedList<DatagramPacket>();
byte[] buf = "hello world".getBytes(); for (InetAddress group : groups) {
packets.add(new DatagramPacket(buf, buf.length, new InetSocketAddress(group, port)));
}
while (!closed) { for (DatagramPacket packet : packets) {
mcastsock.send(packet);
count++;
}
System.out.printf("Sent %d packets from %s\n", count, nic.getName()); Thread.sleep(1000); // sleep 1 second
}
} catch (Exception e) { if (!closed) {
System.err.println("Unexpected exception for MulticastSender("
+ nic.getName() + "): " + e);
e.printStackTrace(); thrownew RuntimeException(e);
}
} finally {
System.out.printf("Sent %d packets from %s\n", count, nic.getName());
}
}
}
@SuppressWarnings("unchecked") class NetIf { privateboolean ipv4Address; //false privateboolean ipv6Address; //false privateint index;
List<InetAddress> groups = Collections.EMPTY_LIST; privatefinal NetworkInterface nic;
¤ Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.0.12Bemerkung:
(vorverarbeitet)
¤
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung ist noch experimentell.