参考文章:
1.Linux 命令神器:lsof
https://www.jianshu.com/p/a3aa6b01b2e1
2.linux lsof 命令详解
https://www.cnblogs.com/sparkbj/p/7161669.html
lsof是系统管理/安全的尤伯工具。将这个工具称之为lsof真实名副其实,因为它是指“列出打开文件(lists openfiles)”。而有一点要切记,在Unix中一切(包括网络套接口)都是文件。
有趣的是,lsof也是有着最多开关的Linux/Unix命令之一。它有那么多的开关,它有许多选项支持使用-和+前缀。
基础介绍
[root@cdh-manager linux_cmd_test]# lsof -h
lsof 4.87
latest revision: ftp://lsof.itap.purdue.edu/pub/tools/unix/lsof/
latest FAQ: ftp://lsof.itap.purdue.edu/pub/tools/unix/lsof/FAQ
latest man page: ftp://lsof.itap.purdue.edu/pub/tools/unix/lsof/lsof_man
usage: [-?abhKlnNoOPRtUvVX] [+|-c c] [+|-d s] [+D D] [+|-f[gG]] [+|-e s]
[-F [f]] [-g [s]] [-i [i]] [+|-L [l]] [+m [m]] [+|-M] [-o [o]] [-p s]
[+|-r [t]] [-s [p:s]] [-S [t]] [-T [t]] [-u s] [+|-w] [-x [fl]] [--] [names]
Defaults in parentheses; comma-separated set (s) items; dash-separated ranges.
-?|-h list help -a AND selections (OR) -b avoid kernel blocks
-c c cmd c ^c /c/[bix] +c w COMMAND width (9) +d s dir s files
-d s select by FD set +D D dir D tree *SLOW?* +|-e s exempt s *RISKY*
-i select IPv[46] files -K list tasKs (threads) -l list UID numbers
-n no host names -N select NFS files -o list file offset
-O no overhead *RISKY* -P no port names -R list paRent PID
-s list file size -t terse listing -T disable TCP/TPI info
-U select Unix socket -v list version info -V verbose search
+|-w Warnings (+) -X skip TCP&UDP* files -Z Z context [Z]
-- end option scan
+f|-f +filesystem or -file names +|-f[gG] flaGs
-F [f] select fields; -F? for help
+|-L [l] list (+) suppress (-) link counts < l (0 = all; default = 0)
+m [m] use|create mount supplement
+|-M portMap registration (-) -o o o 0t offset digits (8)
-p s exclude(^)|select PIDs -S [t] t second stat timeout (15)
-T qs TCP/TPI Q,St (s) info
-g [s] exclude(^)|select and print process group IDs
-i i select by IPv[46] address: [46][proto][@host|addr][:svc_list|port_list]
+|-r [t[m<fmt>]] repeat every t seconds (15); + until no files, - forever.
An optional suffix to t is m<fmt>; m must separate t from <fmt> and
<fmt> is an strftime(3) format for the marker line.
-s p:s exclude(^)|select protocol (p = TCP|UDP) states by name(s).
-u s exclude(^)|select login|UID set s
-x [fl] cross over +d|+D File systems or symbolic Links
names select named files or files on named file systems
Anyone can list all files; /dev warnings disabled; kernel ID check disabled.
可以列出被进程所打开的文件的信息。被打开的文件可以是
1.普通的文件,
2.目录
3.网络文件系统的文件,
4.字符设备文件
5.(函数)共享库
6.管道,命名管道
7.符号链接
8.底层的socket字流,网络socket,unix域名socket
9.在linux里面,大部分的东西都是被当做文件的…..还有其他很多
lsof 的表头信息
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
COMMAND 进程的名称
PID 进程标识符
USER 进程所有者
FD 文件描述符,应用程序通过文件描述符试别该文件。如 cwd. txt 等
TYPE 文件类型,如DIR , REG 等
DEVICE 指定磁盘的名称
SIZE 文件的大小
NODE 索引节点(文件在磁盘的标识)
NAME 打开文件的确切名称
lsof的一些使用示例
这里主要用案例的形式来介绍lsof 命令的使用
列出所有打开的文件:
lsof
备注: 如果不加任何参数,就会打开所有被打开的文件,建议加上一下参数来具体定位
-------------------------------------------------
查看谁正在使用某个文件
lsof /filepath/file
-------------------------------------------------
递归查看某个目录的文件信息
lsof +D /filepath/filepath2/
备注: 使用了+D,对应目录下的所有子目录和文件都会被列出
-------------------------------------------------
比使用+D选项,遍历查看某个目录的所有文件信息 的方法
lsof | grep ‘/filepath/filepath2/’
-------------------------------------------------
列出某个用户打开的文件信息
lsof -u username
备注: -u 选项,u其实是user的缩写
-------------------------------------------------
列出某个进程打开的文件信息
[root@cdh-manager linux_cmd_test]# jps
11872 ThriftServer
12225 RunJar
12097 ResourceManager
11619 RESTServer
33347 JobHistoryServer
13987 Main
12070 HMaster
11751 QuorumPeerMain
13996 EventCatcherService
11726 AlertPublisher
11601 NameNode
11762 Kafka
12213 RunJar
11606 SecondaryNameNode
41852 Jps
9821 Main
14047 Main
看下 Kafka 进程打开了那些文件
[root@cdh-manager linux_cmd_test]# lsof -p 11762 | head
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
java 11762 kafka cwd DIR 0,41 360 57434 /run/cloudera-scm-agent/process/175-kafka-KAFKA_BROKER
java 11762 kafka rtd DIR 253,0 235 64 /
java 11762 kafka txt REG 253,0 8464 8480337 /opt/java_home/jdk1.8.0_191/bin/java
java 11762 kafka mem REG 253,0 10485756 38001682 /var/local/kafka/data/test-topic-2/00000000000000000001.timeindex
java 11762 kafka mem REG 253,0 10485760 38001653 /var/local/kafka/data/test-topic-2/00000000000000000001.index
java 11762 kafka mem REG 253,0 10485756 8372177 /var/local/kafka/data/test-topic-0/00000000000000000002.timeindex
java 11762 kafka mem REG 253,0 10485760 8372176 /var/local/kafka/data/test-topic-0/00000000000000000002.index
java 11762 kafka mem REG 253,0 10485756 103851383 /var/local/kafka/data/test-topic-3/00000000000000000001.timeindex
java 11762 kafka mem REG 253,0 10485760 103851065 /var/local/kafka/data/test-topic-3/00000000000000000001.index
-------------------------------------------------
列出某个程序所打开的文件信息
lsof -c mysql
注意 -c 指定是 cmd
备注: -c 选项将会列出所有以mysql开头的程序的文件,其实你也可以写成lsof | grep mysql,但是第一种方法明显比第二种方法要少打几个字符了
-------------------------------------------------
列出多个程序多打开的文件信息
lsof -c mysql -c apache
-------------------------------------------------
列出某个用户以及某个程序所打开的文件信息
lsof -u test -c mysql
-------------------------------------------------
列出除了某个用户外的被打开的文件信息
lsof -u ^root
备注:^这个符号在用户名之前,将会把是root用户打开的进程不让显示
-------------------------------------------------
通过某个进程号显示该进行打开的文件
lsof -p 1
-------------------------------------------------
列出多个进程号对应的文件信息
lsof -p 123,456,789
-------------------------------------------------
列出除了某个进程号,其他进程号所打开的文件信息
lsof -p ^1
-------------------------------------------------
列出所有的网络连接
lsof -i
-------------------------------------------------
列出所有tcp 网络连接信息
lsof -i tcp
-------------------------------------------------
列出所有udp网络连接信息
lsof -i udp
-------------------------------------------------
列出谁在使用某个端口
lsof -i :3306
-------------------------------------------------
列出基于某种协议下的某个端口的使用
udp 55 端口
lsof -i udp:55
tcp 80 端口
lsof -i tcp:80
-------------------------------------------------
列出某个用户的所有活跃的网络端口
lsof -a -u test -i
-------------------------------------------------
列出所有网络文件系统
lsof -N
-------------------------------------------------
域名socket文件
lsof -u
----------------------------------------
某个用户组所打开的文件信息
lsof -g 5555
------------------------------------------------------
根据文件描述列出对应的文件信息
lsof -d description(like 2)
------------------------------------------------------
根据文件描述范围列出文件信息
lsof -d 2-3