2013-03-04 58 views
3

我想调试一些多播问题,我希望有一些小程序/实用程序来显示传入多播数据包。任何接收指定UDP端口组播数据包的小程序?

从发送机(A),我用理查德·史蒂文斯的sock程序(提供了TCP/IP图鉴VOL1)发送组播数据包(源端口=目的端口= 7000),像这样:

sock -u -b 7000 224.0.0.7 7000 

在接收机器(B)上,我可以用Wireshark捕获发送的数据包,但是,运行在B上的相同的sock命令不报告接收任何内容。

然后,我应该在B上使用什么程序来查看传入的多播数据包,除了Wireshark过度消耗之外。

Linux和Windows程序都是受欢迎的。

enter image description here

回答

7

下面是一个Python脚本,将打印的输入数据;

# Multicast client 
# Adapted from: http://chaos.weblogs.us/archives/164 

import socket 

ANY = "0.0.0.0" 
MCAST_ADDR = "224.0.0.7" 
MCAST_PORT = 7000 

# Create a UDP socket 
sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM, socket.IPPROTO_UDP) 

# Allow multiple sockets to use the same PORT number 
sock.setsockopt(socket.SOL_SOCKET,socket.SO_REUSEADDR,1) 

# Bind to the port that we know will receive multicast data 
sock.bind((ANY,MCAST_PORT)) 

# Tell the kernel that we want to add ourselves to a multicast group 
# The address for the multicast group is the third param 
status = sock.setsockopt(socket.IPPROTO_IP, 
socket.IP_ADD_MEMBERSHIP, 
socket.inet_aton(MCAST_ADDR) + socket.inet_aton(ANY)) 

# setblocking(0) is equiv to settimeout(0.0) which means we poll the socket. 
# But this will raise an error if recv() or send() can't immediately find or send data. 
sock.setblocking(0) 

while 1: 
    try: 
     data, addr = sock.recvfrom(1024) 
    except socket.error as e: 
     pass 
    else: 
     print "From: ", addr 
     print "Data: ", data 
+2

我碰巧知道了Python。你的代码段在Windows XP和Linux(openSUSE 11.3)上效果很好,可以消耗100%的CPU内核。 – 2013-03-12 13:54:27

+0

100%的CPU使用率是由于sock.setblocking(0)造成的,您可能希望使用sock.settimeout(0.1) – Lummo 2016-11-24 08:20:49

1

您可以使用netcat的(NC)要做到这一点:

netcat -vv -l -p 1234 -u 

这意味着netcat的是冗长监听在UDP模式下的本地主机的端口1234。

相关问题