网络数据传输分为三类,单播,广播,组播,其中组播是兼容前两者特点。发送者每次发送的数据可以被组内的所有
接受者收到。在组内的发送者和每一个接受者之间实现点到多点网络传输,也称多点传送。
组播是一种介于单播传输和广播传输之间的一种中间技术。当采用组播方式传送数据包时,发送方只需要发送一份
相同的数据包,通过路由器动态决定数据包的路由,即寻找组播组的地址,只有必要时才赋值数据,然后将数据发送到
这个组的每一个主机中。它可以大大提高数据传送效率,减少了骨干网络出现网络拥塞的可能性。比前两种方式效率都
很好。
下面来演示一下使用Java Socket的组播类实现一个组播的小案例
首先是接收端
package com.bird.test; import java.net.DatagramPacket; import java.net.InetAddress; import java.net.MulticastSocket; import java.util.Date; /** * 组播的客户端 * @author Bird * */ public class MulticastReceive { public static void main(String[] args) throws Exception { test(); } public static void test() throws Exception{ InetAddress group = InetAddress.getByName("224.0.0.2");//组播地址 int port = 8888; MulticastSocket msr = null;//创建组播套接字 try { msr = new MulticastSocket(port); msr.joinGroup(group);//加入连接 byte[] buffer = new byte[8192]; System.out.println("接收数据包启动!(启动时间: "+new Date()+")"); while(true){ //建立一个指定缓冲区大小的数据包 DatagramPacket dp = new DatagramPacket(buffer, buffer.length); msr.receive(dp); String s = new String(dp.getData(),0,dp.getLength()); //解码组播数据包 System.out.println(s); } } catch (Exception e) { e.printStackTrace(); }finally{ if(msr!=null){ try { msr.leaveGroup(group); msr.close(); } catch (Exception e2) { // TODO: handle exception } } } } }
然后是发送端
package com.bird.test; import java.net.DatagramPacket; import java.net.InetAddress; import java.net.MulticastSocket; import java.util.Date; /** * 组播的服务端 * @author Bird * */ public class MulticastSender { public static void server() throws Exception{ InetAddress group = InetAddress.getByName("224.0.0.2");//组播地址 int port = 8888; MulticastSocket mss = null; try { mss = new MulticastSocket(port); mss.joinGroup(group); System.out.println("发送数据包启动!(启动时间"+new Date()+")"); while(true){ String message = "Hello "+new Date(); byte[] buffer = message.getBytes(); DatagramPacket dp = new DatagramPacket(buffer, buffer.length,group,port); mss.send(dp); System.out.println("发送数据包给 "+group+":"+port); Thread.sleep(1000); } } catch (Exception e) { e.printStackTrace(); }finally{ try { if(mss!=null){ mss.leaveGroup(group); mss.close(); } } catch (Exception e2) { // TODO: handle exception } } } public static void main(String[] args) throws Exception { server(); } }
通过开启多个接收端,然后开启发送端,就可以实现组播的效果