一尘不染

Unix域套接字如何区分多个客户端?

linux

TCP具有元组对(IP地址/端口/类型)来告诉另一个客户端。UDP传递客户端IP和端口。unix域如何跟踪不同的客户端?

换句话说,服务器创建一个绑定到某个路径的套接字,例如/ tmp / socket。2个或更多客户端连接到/ tmp /
socket。底层发生了什么,可跟踪来自client1和client2的数据?我想网络堆栈在域套接字中不起作用,所以内核在这里完成所有工作吗?

是否有unix域协议格式,例如IP协议格式和TCP /
UDP格式?域套接字数据报协议的格式是否发布在某处?每个Unix是否有所不同,或者类似POSIX的标准吗?

感谢您的照明。我找不到任何解释此信息的信息。每个来源都只是掩盖了如何使用域套接字。


阅读 758

收藏
2020-06-03

共1个答案

一尘不染

如果创建PF_UNIX类型为的套接字SOCK_STREAM并接受其上的连接,则每次接受连接时,都会得到一个新的文件描述符(作为accept系统调用的返回值)。该文件描述符在客户端进程中从文件描述符读取数据并将数据写入文件描述符。因此,它的工作方式就像TCP
/ IP连接一样。

没有“
unix域协议格式”。不需要这样,因为不能通过网络连接将Unix域套接字连接到对等方。在内核中,代表您的SOCK_STREAMUnix域套接字末端的文件描述符指向一个数据结构,该数据结构告诉内核哪个文件描述符位于连接的另一端。当您将数据写入文件描述符时,内核会在连接的另一端查找文件描述符,并将数据附加到该其他文件描述符的读取缓冲区。内核不需要将数据放入带有描述其目的地的标头的数据包中。

对于SOCK_DGRAM套接字,您必须告诉内核应该接收数据的套接字的路径,并使用该路径查找该接收套接字的文件描述符。

如果在连接到服务器套接字之前(或者在使用来发送数据之前)将路径绑定到客户端套接字SOCK_DGRAM,则服务器进程可以使用getpeername(for
SOCK_STREAM)获取该路径。对于a SOCK_DGRAM,接收方可以recvfrom用来获取发送套接字的路径。

如果不绑定路径,则接收过程将无法获得唯一标识对等方的ID。至少,不是在我正在运行的Linux内核上(2.6.18-238.19.1.el5)。

2020-06-03