由于近期在项目中遇到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连接,此处很明确的证明了我的猜测。