1

这工作正常:

socket(PF_INET, SOCK_DGRAM, IPPROTO_IP) = 4
setsockopt(4, SOL_SOCKET, SO_REUSEADDR, [1], 4) = 0
bind(4, {sa_family=AF_INET, sin_port=htons(4444), sin_addr=inet_addr("0.0.0.0")}, 16) = 0
connect(4, {sa_family=AF_INET, sin_port=htons(0), sin_addr=inet_addr("1.1.1.1")}, 16) = 0

我们可以观察到本地和远程的正确绑定:

$ sudo lsof -Pni :4444
COMMAND  PID USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
udpdup  2815 nhed    4u  IPv4 126724      0t0  UDP 10.0.2.15:4444->1.1.1.1:* 

但是把连接放在第一位,在绑定时得到一个错误,为什么?

socket(PF_INET, SOCK_DGRAM, IPPROTO_IP) = 4
setsockopt(4, SOL_SOCKET, SO_REUSEADDR, [1], 4) = 0
connect(4, {sa_family=AF_INET, sin_port=htons(0), sin_addr=inet_addr("1.1.1.1")}, 16) = 0
bind(4, {sa_family=AF_INET, sin_port=htons(4444), sin_addr=inet_addr("0.0.0.0")}, 16) = -1 EINVAL (Invalid argument)





我为什么在乎你问?

我认为接收到的数据包与 5 元素元组(proto、loc addr、loc port、rem addr、rem port)匹配。其中 5 个中的一些可以是 ANY(通配符),用数字表示00.0.0.0instruct sockaddr_in并且经常用 , 等表示netstatlsof上面的lsof输出显示指定了 4/5 个元素,远程端口保留为通配符)

我不记得是否应该存在多个套接字,其中一些具有通配符对等地址,而另一些可能是显式的,根据最佳匹配将流量发送到正确的端口。

我想试验并检查当一个应用程序绑定一个端口而不指定发送者地址时,另一个应用程序可以连接和绑定对等点,以形成一个更完整的元组。[注意第一个应用程序没有指定SO_REUSEADDR]

ps 有足够积分的人可以创建一个udp-connect标签吗?(甚至是 udp 绑定)

4

1 回答 1

1

connect(2)隐式绑定您的本地端口,因此后续显式bind(2)失败。

编辑0:

您可以将多个套接字绑定到同一个本地端口,但第一个之后的所有绑定必须更具体。比如说,第一个套接字绑定到INADDR_ANY,其他的绑定到现有网络接口的特定地址。请注意,所有套接字都必须设置为SO_REUSEADDR.

然后是多播,它允许您创建完全重复的套接字绑定,但仅限于特定类别的地址,并且您必须做更多的工作来设置它。

在我看来,您也将此与 TCP 侦听与连接的套接字混淆了。

编辑1:

connect(2)还根据到目的地的路由修复套接字本地地址。

于 2013-06-01T16:08:55.730 回答