lsof
Everything in Unix is a file,而lsof能够list open files,所以足见它的重要性。
wikipedia lsof
Examples
Open files in the system include disk files, named pipes, network sockets and devices opened by all processes.
The listing of open files can be consulted (suitably filtered if necessary) to identify the process that is using the files.
# lsof /var
COMMAND     PID     USER   FD   TYPE DEVICE SIZE/OFF   NODE NAME
syslogd     350     root    5w  VREG  222,5        0 440818 /var/adm/messages
syslogd     350     root    6w  VREG  222,5   339098   6248 /var/log/syslog
cron        353     root  cwd   VDIR  222,5      512 254550 /var -- atjobs
To view the port associated with a daemon:
# lsof -i -n -P | grep sendmail
sendmail  31649    root    4u  IPv4 521738       TCP *:25 (LISTEN)
From the above one can see that "sendmail" is listening on its standard port of "25".
- -i
Lists IP sockets.
- -n
Do not resolve hostnames (no DNS).
- -P
Do not resolve port names (list port number instead of its name).
One can also list Unix Sockets by using lsof -U.
lsof(8) - Linux man page
lsof - list open files
NOTE: 显然,使用这个command,需要对Linux的文件有着非常详细的认识,下面总结了不同类型的file和其对应的option;在原文的Output段中,对文件类型进行了详细的说明,据此可以知道OS所支持的所有的文件类型。
Options
file type
| 文件类型 | list request option | |
|---|---|---|
| regular file | ||
| directory | ||
| block special file | ||
| character special file | ||
| executing text reference | ||
| library | ||
| Internet socket | -i | |
| NFS file | -N | |
| UNIX domain socket | -U | 
A specific file or all the files in a file system may be selected by path.
user
-u
NOTE: 下面是tecmint 10 lsof Command Examples in Linux中给出的简介: display the list of all opened files of user tecmint.
# lsof -u tecmint COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME sshd 1838 tecmint cwd DIR 253,0 4096 2 /
PID
NOTE: 下面是tecmint 10 lsof Command Examples in Linux中给出的简介:
9. Search by PID
The below example only shows whose PID is 1 [One].
# lsof -p 1 COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME init 1 root cwd DIR 253,0 4096 2 /
Exclude
NOTE: 10 lsof Command Examples in Linux:
Exclude User with ‘^’ Character
Here, we have excluded root user. You can exclude a particular user using ‘^’ with command as shown above.
# lsof -i -u^root COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME rpcbind 1203 rpc 6u IPv4 11326 0t0 UDP *:sunrpc rpcbind 1203 rpc 7u IPv4 11330 0t0 UDP *:954
Output
NOTE:
读懂输出的一个重要前提是清楚输出中各列的含义,原文对此进行了详细说明,但是冗长。下面是tecmint 10 lsof Command Examples in Linux中给出的简介
# lsof COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME init 1 root cwd DIR 253,0 4096 2 / init 1 root txt REG 253,0 145180 147164 /sbin/init init 1 root 0u CHR 1,3 0t0 3764 /dev/null init 1 root 3r FIFO 0,8 0t0 8449 pipe init 1 root 5r DIR 0,10 0 1 inotify init 1 root 7u unix 0xc1513880 0t0 8450 socket
FD
NOTE:下面是tecmint 10 lsof Command Examples in Linux中给出的简介:
FD – stands for File descriptor and may seen some of the values as:
- cwd current working directory
- rtd root directory
- txt program text (code and data)
- mem memory-mapped file
Also in FD column numbers like 1u is actual file descriptor and followed by u,r,w of it’s mode as:
- r for read access.
- w for write access.
- u for read and write access.
COMMAND
NOTE: 即命令
TYPE
NOTE: 文件类型,下面是tecmint 10 lsof Command Examples in Linux中给出的简介:
TYPE – of files and it’s identification.
- DIR – Directory
- REG – Regular file
- CHR – Character special file.
- FIFO – First In First Out
is the type of the node associated with the file - e.g., GDIR, GREG, VDIR, VREG, etc.
Examples
Find Processes running on Specific Port
stackexchange Kill process running on port 80 # A:
There are several ways to find which running process is using a port.
Using fuser it will give the PID(s) of the multiple instances associated with the listening port.
sudo apt-get install psmisc
sudo fuser 80/tcp
80/tcp:               1858  1867  1868  1869  1871
After finding out, you can either stop or kill the process(es).
You can also find the PIDs and more details using lsof
sudo lsof -i tcp:80
COMMAND  PID     USER   FD   TYPE DEVICE SIZE/OFF NODE NAME  
nginx   1858     root    6u  IPv4   5043      0t0  TCP ruir.mxxx.com:http (LISTEN)  
nginx   1867 www-data    6u  IPv4   5043      0t0  TCP ruir.mxxx.com:http (LISTEN)  
To limit to sockets that listen on port 80 (as opposed to clients that connect to port 80):
sudo lsof -i tcp:80 -s tcp:listen
To kill them automatically:
sudo lsof -t -i tcp:80 -s tcp:listen | sudo xargs kill
10 lsof Command Examples in Linux:
To find out all the running process of specific port, just use the following command with option -i. The below example will list all running process of port 22.
# lsof -i TCP:22
COMMAND  PID    USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
sshd    1471    root    3u  IPv4  12683      0t0  TCP *:ssh (LISTEN)
sshd    1471    root    4u  IPv6  12685      0t0  TCP *:ssh (LISTEN)
see also:
List Only IPv4 & IPv6 Open Files
10 lsof Command Examples in Linux:
In below example shows only IPv4 and IPv6 network files open with separate commands.
# lsof -i 4
COMMAND    PID    USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
rpcbind   1203     rpc    6u  IPv4  11326      0t0  UDP *:sunrpc
# lsof -i 6
COMMAND    PID    USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
rpcbind   1203     rpc    9u  IPv6  11333      0t0  UDP *:sunrpc
List Open Files of TCP Port ranges 1-1024
10 lsof Command Examples in Linux:
To list all the running process of open files of TCP Port ranges from 1-1024.
# lsof -i TCP:1-1024
COMMAND  PID    USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
rpcbind 1203     rpc   11u  IPv6  11336      0t0  TCP *:sunrpc (LISTEN)
cupsd   1346    root    7u  IPv4  12113      0t0  TCP localhost:ipp (LISTEN)
List all Network Connections
10 lsof Command Examples in Linux:
The following command with option ‘-i’ shows the list of all network connections ‘LISTENING & ESTABLISHED’.
# lsof -i
COMMAND    PID    USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
rpcbind   1203     rpc    6u  IPv4  11326      0t0  UDP *:sunrpc
rpcbind   1203     rpc    7u  IPv4  11330      0t0  UDP *:954
rpcbind   1203     rpc   11u  IPv6  11336      0t0  TCP *:sunrpc (LISTEN)
avahi-dae 1241   avahi   13u  IPv4  11579      0t0  UDP *:mdns
avahi-dae 1241   avahi   14u  IPv4  11580      0t0  UDP *:58600
rpc.statd 1277 rpcuser   11u  IPv6  11862      0t0  TCP *:56428 (LISTEN)
cupsd     1346    root    6u  IPv6  12112      0t0  TCP localhost:ipp (LISTEN)
cupsd     1346    root    7u  IPv4  12113      0t0  TCP localhost:ipp (LISTEN)
sshd      1471    root    3u  IPv4  12683      0t0  TCP *:ssh (LISTEN)
master    1551    root   12u  IPv4  12896      0t0  TCP localhost:smtp (LISTEN)
master    1551    root   13u  IPv6  12898      0t0  TCP localhost:smtp (LISTEN)
sshd      1834    root    3r  IPv4  15101      0t0  TCP 192.168.0.2:ssh->192.168.0.1:conclave-cpp (ESTABLISHED)
Kill all Activity of Particular User
10 lsof Command Examples in Linux:
Sometimes you may have to kill all the processes for a specific user. Below command will kills all the processes of tecmint user.
# kill -9 `lsof -t -u tecmint`