网络 – 多播UDP无法正常工作

覆盆子pi上的多播UDP

我没有把事情缩小到足以知道我的问题是因为debian,特别是raspbian,还是我完全错过了一些东西.

我有一个python应用程序,它使用多播UDP让网络上的其他设备知道我的应用程序已启动并运行并在特定IP地址可用.

UDP组播组是239.255.250.250,端口是9131.如果我运行tcpdump,我可以看到我尝试发送的数据包实际上是在发送数据,但我从未在网络上的其他计算机上看到任何内容.

还有其他设备使用相同类型的“beacon”具有相同的多播组和端口,我可以看到这些数据包在其他计算机上通过.路由器没有防火墙,此时我真的没有选择.

以下是我知道如何运行的基本诊断.糟糕的udp chksum看起来可能没有帮助,但我对此并不了解.

输出ifconfig

eth0      Link encap:Ethernet  HWaddr b8:27:eb:b2:79:12  
          inet addr:192.168.2.7  Bcast:192.168.2.255  Mask:255.255.255.0
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:1682 errors:0 dropped:0 overruns:0 frame:0
          TX packets:1686 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000 
          RX bytes:119105 (116.3 KiB)  TX bytes:169570 (165.5 KiB)

应用程序运行时输出tcpdump

    tcpdump: listening on eth0, link-type EN10MB (Ethernet), capture size 65535 bytes
03:29:15.722653 IP (tos 0x0, ttl 1, id 0, offset 0, flags [DF], proto UDP (17), length 221)
    192.168.2.7.33335 > 239.255.250.250.9131: [bad udp cksum 0xae84 -> 0xaabe!] UDP, length 193
    0x0000:  4500 00dd 0000 4000 0111 cb66 c0a8 0207  E.....@....f....
    0x0010:  efff fafa 8237 23ab 00c9 ae84 414d 5842  .....7#.....AMXB
    0x0020:  3c4d 4143 2d41 4444 523d 6238 3a32 373a  <MAC-ADDR=b8:27:
    0x0030:  6562 3a62 323a 3739 3a31 323e 3c2d 5555  eb:b2:79:12><-UU
    0x0040:  4944 3d32 3032 3438 3135 3937 3537 3734  ID=2024815975774
    0x0050:  3930 3e3c 2d53 444b 436c 6173 733d 5574  90><-SDKClass=Ut
    0x0060:  696c 6974 793e 3c2d 4d61 6b65 3d69 5275  ility><-Make=iRu
    0x0070:  6c65 426f 783e 3c2d 4d6f 6465 6c3d 5265  leBox><-Model=Re
    0x0080:  6d6f 7465 426f 783e 3c2d 5265 7669 7369  moteBox><-Revisi
    0x0090:  6f6e 3d30 2e31 3e3c 2d50 6b67 5f4c 6576  on=0.1><-Pkg_Lev
    0x00a0:  656c 3d47 4350 4b30 3032 3e3c 2d43 6f6e  el=GCPK002><-Con
    0x00b0:  6669 672d 5552 4c3d 6874 7470 3a2f 2f31  fig-URL=http://1
    0x00c0:  3932 2e31 3638 2e32 2e37 3a38 303e 3c2d  92.168.2.7:80><-
    0x00d0:  5374 6174 7573 3d52 6561 6479 3e         Status=Ready>
^C
1 packet captured
1 packet received by filter
0 packets dropped by kernel

程序运行时netstat的输出

Active Internet connections (servers and established)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name
udp        0      0 0.0.0.0:31144           0.0.0.0:*                           1510/dhclient   
udp        0      0 0.0.0.0:33335           0.0.0.0:*                           2089/python     
udp        0      0 0.0.0.0:68              0.0.0.0:*                           1510/dhclient   
udp        0      0 192.168.2.7:123         0.0.0.0:*                           1911/ntpd       
udp        0      0 0.0.0.0:123             0.0.0.0:*                           1911/ntpd  
最佳答案
我知道您的主机192.168.2.7正在端口9131上向组239.255.250.250发送组播数据包

注意:我假设服务器正在侦听端口9131.您没有提供任何有关此信息的信息.

从ifconfig输出,我可以看到启用了MULTICAST并且tcpdump确认了这一点.

首先确保运行服务器的主机(接收组播数据包的主机)已加入组播组.

在每个服务器主机类型上:

netstat -gn

如果您看到多播地址,则表示已加入该组.
如果没有,那么您的服务器程序或内核设置可能出现问题.

如果服务器已加入该组,但您没有看到从客户端传入的任何数据包,请检查您的路由器是否已启用igmp(您的路由器必须具有igmp功能)

例如,在cisco路由器上

enable
conf t
ip multicast-routing
For each interface involved.
int <NIC>
ip pim sparse-dense-mode

如果在路由器上启用了igmp,请查找用于跟踪数据包的调试功能.

在服务器端,启动数据包捕获:

tcpdump -i <NIC> host 239.255.250.250

如果您没有看到任何数据包进入,则不会转发组播数据包(假设为

然后在客户端发送一个多播数据包(使用下面链接中的脚本进行故障排除)

注意:UDP数据包似乎格式不正确,因此不确定服务器是否能够读取它.您可以使用下面链接中的脚本来确认tcpdump中的消息是否显示为格式错误(它们不在我的情况下)

使用多播的python代码示例:

https://stackoverflow.com/questions/603852/multicast-in-python

注意:我在debian raspi上使用这个脚本(不是通过路由器的raspbian和服务器接收的数据包 – 如上面的设置 – 很好)

Linux指南:http://stlinux.com/howto/network/short-guide

思科:http://www.cisco.com/c/en/us/td/docs/switches/lan/catalyst3750/software/release/12-2_52_se/configuration/guide/3750scg/swmcast.html#wp1024278

转载注明原文:网络 – 多播UDP无法正常工作 - 代码日志