>我跑了:
# lsof | grep 10900
及其输出:
MyExecutab 103497 myuser 7u IPv4 985833 0t0 UDP my.example.com:10900
MyExecutab 103497 103498 myuser 7u IPv4 985833 0t0 UDP my.example.com:10900
MyExecutab 103497 103499 myuser 7u IPv4 985833 0t0 UDP my.example.com:10900
MyExecutab 103497 103500 myuser 7u IPv4 985833 0t0 UDP my.example.com:10900
MyExecutab 103497 103501 myuser 7u IPv4 985833 0t0 UDP my.example.com:10900
MyExecutab 103497 103502 myuser 7u IPv4 985833 0t0 UDP my.example.com:10900
MyExecutab 103497 103503 myuser 7u IPv4 985833 0t0 UDP my.example.com:10900
我正在尝试找出哪个线程正在从UDP端口10900读取。
似乎有 7 个线程从该端口读取,是真的吗?
我觉得实际上只有一个线程在读取,但 lsof 只是列出了所有子线程(在同一进程中(和父线程。
netstat -plun
显示只有父线程 (PID( 在侦听该端口:
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
udp 0 0 10.7.168.173:10900 0.0.0.0:* 103497/MyExecutable
我还检查了/proc/[pid]/fd
. 因为只有103497是 PID,所以其余的都是 TID,所以/proc/
只有 103497 而没有其余的。
那么真的有办法弄清楚哪个线程侦听特定的UDP端口吗?
我使用的是 CentOS 7(内核 3.10(。
谢谢!
运行strace -ffp <pid>
并查看哪些线程使用文件描述符 7。