哪个线程侦听特定的 UDP 端口



>我跑了:

# 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。

最新更新