2013-03-04 205 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。