Lsof是遵從Unix哲學的典范,它只完成一個功能,並且做的相當完美——它可以列出某個進程打開的所有文件信息。打開的文件可能是普通的文件、目錄、NFS文件、塊文件、字符文件、共享庫、常規管道、命名管道、符號鏈接、Socket流、網絡Socket、UNIX域Socket,以及其它更多類型。因為“一切皆文件”乃為Unix系統的重要哲學思想之一,因此可以想象lsof命令的重要地位。
lsof [options] filename
lsof /path/to/somefile:顯示打開指定文件的所有進程之列表
lsof -c string:顯示其COMMAND列中包含指定字符(string)的進程所有打開的文件;此選項可以重復使用,以指定多個模式;
lsof -p PID:查看該進程打開了哪些文件;進程號前可以使用脫字符“^”取反;
lsof -u USERNAME:顯示指定用戶的進程打開的文件;用戶名前可以使用脫字符“^”取反,如“lsof -u ^root”則用於顯示非root用戶打開的所有文件;
lsof -g GID:顯示歸屬gid的進程情況
lsof +d /DIR/:顯示指定目錄下被進程打開的文件
lsof +D /DIR/:基本功能同上,但lsof會對指定目錄進行遞歸查找,注意這個參數要比grep版本慢:
lsof -a:按“與”組合多個條件,如lsof -a -c apache -u apache
lsof -N:列出所有NFS(網絡文件系統)文件
lsof -d FD:顯示指定文件描述符的相關進程;也可以為描述符指定一個范圍,如0-2表示0,1,2三個文件描述符;另外,-d還支持其它很多特殊值,如:
mem: 列出所有內存映射文件;
mmap:顯示所有內存映射設備;
txt:列出所有加載在內存中並正在執行的進程,包含code和data;
cwd:正在訪問當前目錄的進程列表;
lsof -n:不反解IP至HOSTNAME
lsof -i:用以顯示符合條件的進程情況
lsof -i[46] [protocol][@hostname|hostaddr][:service|port]
46:IPv4或IPv6
protocol:TCP or UDP
hostname:Internet host name
hostaddr:IPv4地址
service:/etc/service中的服務名稱(可以不只一個)
port:端口號 (可以不只一個)
例如: 查看22端口現在運行的情況
[root@www ~]# lsof -i :22
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
sshd 1390 root 3u IPv4 13050 0t0 TCP *:ssh (LISTEN)
sshd 1390 root 4u IPv6 13056 0t0 TCP *:ssh (LISTEN)
sshd 36454 root 3r IPv4 94352 0t0 TCP www.magedu.com:ssh->172.16.0.1:50018 (ESTABLISHED)
上述命令中,每行顯示一個打開的文件,若不指定條件默認將顯示所有進程打開的所有文件。lsof輸出各列信息的意義如下:
COMMAND:進程的名稱
PID:進程標識符
USER:進程所有者
FD:文件描述符,應用程序通過文件描述符識別該文件。如cwd、txt等
TYPE:文件類型,如DIR、REG等
DEVICE:指定磁盤的名稱
SIZE:文件的大小
NODE:索引節點(文件在磁盤上的標識)
NAME:打開文件的確切名稱