Tim Asked: 2019-03-25 13:42:56 +0800 CST2019-03-25 13:42:56 +0800 CST 2019-03-25 13:42:56 +0800 CST 哪些 IP 地址不能绑定到侦听套接字? 772 哪些 IP 地址不能绑定到侦听套接字? 例如,服务器进程能否将 255.255.255.255 绑定到监听套接字? 谢谢。 socket ip-address 1 个回答 Voted Best Answer telcoM 2019-03-25T14:24:56+08:002019-03-25T14:24:56+08:00 从 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,请参见数据包 (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_FREEBINDsocket 选项,你可以绑定到任何地址,假设绑定到的地址可能会在稍后出现在某个本地接口上。但是,在这种情况真正发生之前,以这种方式绑定的套接字可能不是很有用。 Linux 也有一个SO_BINDTODEVICE套接字选项,可用于将套接字绑定到特定的网络接口,而无需指定其 IP 地址。
从 Linux
bind(2)
手册页:对于 IPv4,
ip(7)
手册页说:因此,对于 IPv4 TCP 或 UDP 套接字,要绑定的 IP 必须是
INADDR_ANY
分配给本地系统上任何网络接口的 IP 地址之一或其中一个。但它也说:
因此,绑定到 255.255.255.255 是有效的,并且具有与 0.0.0.0 相同的效果,但在现代实现中,0.0.0.0 是首选。
如果你设置了
IP_FREEBIND
socket 选项,你可以绑定到任何地址,假设绑定到的地址可能会在稍后出现在某个本地接口上。但是,在这种情况真正发生之前,以这种方式绑定的套接字可能不是很有用。Linux 也有一个
SO_BINDTODEVICE
套接字选项,可用于将套接字绑定到特定的网络接口,而无需指定其 IP 地址。