第一次海报,希望这是一个简单的:
我需要向一个硬件发送一个广播数据包,当它启动时,它与我的机器位于不同的子网中,以便告诉它将其 IP 地址重置为我网络上的一个。但是,除非我使用 DHCP,否则我似乎无法从自己的子网广播,最终我将无法做到。网络上没有路由器,只是在我的机器和我要与之交谈的机器之间进行简单的切换,再加上网络上的其他几台 Linux 机器。
所以基本上这个示例代码在测试环境中的 Fedora 19 上工作(在我启用了 DHCP 的更大网络上),直到我尝试静态设置我的 IP 地址:
int main(int argc, char *argv[])
{
int sock;
if( (sock = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP)) == -1)
{
perror("socket : ");
return -1;
}
int broadcast = 1;
if( setsockopt(sock, SOL_SOCKET, SO_BROADCAST, &broadcast, sizeof(broadcast)) != 0 )
{
perror("setsockopt : ");
close(sock);
return -1;
}
char *ip = "255.255.255.255";
char * msg = "Hello World!";
struct sockaddr_in si;
si.sin_family = AF_INET;
si.sin_port = htons( 4444 );
inet_aton( ip, &si.sin_addr.s_addr );
/* send data */
size_t nBytes = sendto(sock, msg, strlen(msg), 0,
(struct sockaddr*) &si, sizeof(si));
printf("Sent msg: %s, %d bytes with socket %d to %s\n", msg, nBytes, sock, ip);
return 0;
}
如果我使用的是 DHCP,则输出为:
Sent msg: Hello World!, 12 bytes with socket 3 to 255.255.255.255
我可以看到数据包在 Wireshark 中发出。
然后,如果我将我的 IP 静态设置为 192.168.100.1,我会得到:
Sent msg: Hello World!, -1 bytes with socket 3 to 255.255.255.255
而且我在 Wireshark 中看不到数据包。而且我可以确认 ifconfig 中显示的 TX 数据包数量不会增加。我尝试禁用防火墙:
sudo iptables -F
但这并没有做任何事情。有人看到我缺少的东西吗?我可以广播到 192.168.100.255,但这不会到达我需要与之交谈的框,例如默认情况下可能位于 192.168.200.10、255.255.255.0。我可以通过更改网络上其他所有内容的网络参数来使其工作,但这并不是一个真正的选择。
编辑:关于一些评论和答案,请注意我没有使用路由器,并且可以在我的计算机和另一个盒子之间只用一根电线复制行为。所以,真正的问题是,为什么 Linux 不发送数据包?我显然不知道,但我怀疑 Linux 本身会丢弃跨子网广播数据包,除非它可以将该决定委托给网络上的另一个权威。无论如何,鉴于我的网络是如此之小,我只需要解决它。