我需要使用 RAW 套接字接收传入的 UDP 数据包,该套接字正在使用以下代码片段打开:
static int fd;
char *iface;
iface = "eth0";
if ( (fd = socket(PF_PACKET, SOCK_DGRAM, htons(ETH_P_IP))) < 0 )
{
perror("socket");
}
if (setsockopt(fd, SOL_SOCKET, SO_BINDTODEVICE, iface, strlen(iface)) < 0)
{
perror("bind");
exit(EXIT_FAILURE);
}
例如,我发送 100 个相同的数据包并尝试接收并计算它们。我使用 recv(...) 来做到这一点。只有 93 个数据包被传递,然后 recv(...) 挂起等待下一个数据包。但是,如果我在接收端计算机上运行“Wireshark”(使用 libpcap)并让它在“eth0”上监听 UDP 数据包,那么我的应用程序将始终捕获 100 个数据包而没有任何问题。
我不明白我实际上做错了什么,为什么“Wireshark”也会影响我的套接字接收器?
PS 我已经尝试增加接收缓冲区大小,但没有成功。