哪些 IP 地址不能绑定到侦听套接字?

哪些 IP 地址不能绑定到侦听套接字?

哪些 IP 地址不能绑定到侦听套接字?

例如,服务器进程可以将 255.255.255.255 绑定到侦听套接字吗?

谢谢。

答案1

来自 Linuxbind(2)手册页:

在 SOCK_STREAM 套接字可以接收连接之前,通常需要使用bind() 分配本地地址(请参阅accept(2))。

名称绑定中使用的规则因地址族而异。有关详细信息,请参阅第 7 节中的手册条目。对于 AF_INET,请参见 ip(7);对于 AF_INET6,请参阅 ipv6(7);对于 AF_UNIX,请参阅 unix(7);对于 AF_APPLETALK,请参见 ddp(7);对于 AF_PACKET,请参见 packet(7);对于 AF_X25,请参见 x25(7);对于 AF_NETLINK,请参阅 netlink(7)。

对于 IPv4,ip(7)手册页显示:

当进程想要接收新的传入数据包或连接时,它应该使用bind(2)将套接字绑定到本地接口地址。在这种情况下,只有一个 IP 套接字可以绑定到任何给定的本地(地址、端口)对。当在绑定调用中指定 INADDR_ANY 时,套接字将绑定到所有本地接口。当在未绑定的套接字上调用listen(2)时,该套接字会自动绑定到本地地址设置为INADDR_ANY的随机空闲端口。

因此,对于 IPv4 TCP 或 UDP 套接字来说,要绑定的 IP 必须是INADDR_ANY分配给本地系统上任何网络接口的 IP 地址之一或其中之一。

但它也说:

有几个特殊地址: INADDR_LOOPBACK (127.0.0.1) 总是通过环回设备引用本地主机; INADDR_ANY (0.0.0.0) 表示任意地址进行绑定; INADDR_BROADCAST (255.255.255.255) 表示任何主机,由于历史原因,对绑定具有与 INADDR_ANY 相同的效果。

因此,绑定到 255.255.255.255 是有效的,并且具有与 0.0.0.0 相同的效果,但在现代实现中,0.0.0.0 是首选。

如果设置了IP_FREEBIND套接字选项,则可以绑定到任何地址,假设绑定的地址稍后可能会出现在某个本地接口上。然而,在这实际发生之前,以这种方式绑定的套接字可能不是很有用。

Linux 还有一个SO_BINDTODEVICE套接字选项,可用于将套接字绑定到特定网络接口,而无需指定其 IP 地址。

相关内容