linux下查看进程使用文件描述符的详细信息

xiaoxiao2021-02-28  85

        由于近期在项目中遇到socket通信,和服务器端建立了TCP连接,但是要向服务器发送的数据却没发上去,分析没发出去的原因可能是:应用程序进程把文件描述符0关闭了,然后socket获取到了0作为socket通信的文件描述符,然后建立TCP成功,但是由于0是系统的标准输入文件描述符,导致发送数据异常。

       上述的原因只是推测,并没有确切的证据,正好今天早上发现现场的设备出现不上去报文的情况,所以想自己查看一下情况,找到原因的确切证据,故问度娘要相关信息,度娘说,要查看进程的相关详细信息,都在/proc/PID/下的目录中。下面以进程号820为例来说。我想查看文件描述符0用于什么用途了,使用命令

     ls -l /proc/820/fd 或 ll /proc/820/fd

命令会列出fd下每个文件的详细信息,能够看到每个文件描述符对应的文件,或者用途。

命令在我故障设备上的运行结果如下:

[root@jx fd]#ll /proc/820/fd total 0 dr-x------    2 root     root             0 Aug  7 08:30 . dr-xr-xr-x    7 root     root             0 Jul 31 10:10 .. lrwx------    1 root     root            64 Aug  7 09:13 0 -> socket:[26598188] l-wx------    1 root     root            64 Aug  7 09:13 1 -> /dev/null l-wx------    1 root     root            64 Aug  7 09:13 2 -> /dev/null lrwx------    1 root     root            64 Aug  7 09:13 3 -> /mnt/database/Configdb.db lrwx------    1 root     root            64 Aug  7 09:13 4 -> /mnt/database/RetransmitData.db lrwx------    1 root     root            64 Aug  7 09:13 5 -> /mnt/database/Hisdatadb.db lrwx------    1 root     root            64 Aug  7 09:13 6 -> /mnt/database/Curdatadb.db

文件描述0用于socket连接,此处很明确的证明了我的猜测。

       

转载请注明原文地址: https://www.6miu.com/read-70026.html

最新回复(0)