当我想查看使用ls -l /proc/pid/fd
的进程的打开文件列表时,我看到了一些套接字描述符。如何找到相应的文件名?
lr-x------ 1 u1 users 64 Sep 15 14:45 0 -> /dev/null
lrwx------ 1 u1 users 64 Sep 15 14:45 1 -> /dev/pts/3
lrwx------ 1 u1 users 64 Sep 15 14:45 10 -> socket:[507942]
l-wx------ 1 u1 users 64 Sep 15 14:45 2 -> pipe:[505993]
l-wx------ 1 u1 users 64 Sep 15 14:45 22 -> pipe:[505994]
l-wx------ 1 u1 users 64 Sep 15 14:45 3 -> /dev/null
lrwx------ 1 u1 users 64 Sep 15 14:45 4 -> socket:[507938]
lrwx------ 1 u1 users 64 Sep 15 14:45 5 -> socket:[507939]
lrwx------ 1 u1 users 64 Sep 15 14:45 6 -> socket:[486323]
lrwx------ 1 u1 users 64 Sep 15 14:45 7 -> socket:[486324]
lrwx------ 1 u1 users 64 Sep 15 14:45 8 -> socket:[509999]
lrwx------ 1 u1 users 64 Sep 15 14:45 9 -> socket:[507941]
使用lsof -p pid
我也看到套接字。
atIcoFoam 24376 u1 0r CHR 1,3 0t0 1029 /dev/null
atIcoFoam 24376 u1 1u CHR 136,3 0t0 6 /dev/pts/3
atIcoFoam 24376 u1 2w FIFO 0,8 0t0 506122 pipe
atIcoFoam 24376 u1 3w CHR 1,3 0t0 1029 /dev/null
atIcoFoam 24376 u1 4u unix 0x0000000000000000 0t0 511127 socket
atIcoFoam 24376 u1 5u unix 0x0000000000000000 0t0 511128 socket
atIcoFoam 24376 u1 6u IPv4 510153 0t0 TCP *:37340 (LISTEN)
atIcoFoam 24376 u1 7u IPv6 510154 0t0 TCP *:43305 (LISTEN)
atIcoFoam 24376 u1 8u IPv4 512654 0t0 TCP hpclab.ws05:57696->hpclab.ws05:33141 (ESTABLISHED)
atIcoFoam 24376 u1 9u IPv4 508030 0t0 TCP *:1027 (LISTEN)
atIcoFoam 24376 u1 10u IPv6 508031 0t0 TCP *:1027 (LISTEN)
答案 0 :(得分:1)
仅命名的UNIX域名套接字(AF_UNIX
类型套接字)具有关联的文件。
<强>更新强>
此文件的名称使用此套接字的文件描述符的特定于进程的值链接到/proc/<process id>/fd/
目录。
所有其他套接字在文件系统中没有表示。
答案 1 :(得分:0)
您可以通过以下方式列出打开的文件:
lsof -p PID
答案 2 :(得分:0)
这些是UNIX侦听套接字吗?我认为是的,因为如果它们是其他任何东西那么你的问题就没有意义了。
lsof
通常能够解析套接字绑定的文件系统名称:
lsof -p pid