一、介绍
lsof(list open files)是一个列出当前系统打开文件的工具。在linux环境下,任何事物都以文件的形式存在,通过文件不仅仅可以访问常规数据,还可以访问网络连接和硬件。
传输控制协议 (TCP) 和用户数据报协议 (UDP) 套接字等,系统在后台都为该应用程序分配了一个文件描述符,无论这个文件的本质如何,该文件描述符为应用程序与基础操作系统之间的交互提供了通用接口。因为应用程序打开文件的描述符列表提供了大量关于这个应用程序本身的信息,因此通过lsof工具能够查看这个列表,对系统监测和排错很有帮助。
字段含义
在终端下输入lsof 即可显示系统打开的文件, lsof 一般需要访问核心内存和各种文件,所以必须以 root 用户的身份运行它才能够充分地发挥其功能。
二、安装
yum -y install lsof
三、参数说明
-?, -h 显示帮助信息
-a 参数被视为逻辑与 AND,会影响全部的参数
-A A 在配置了 AFS 分布式网络文件系统的系统上可用,其 AFS 内核代码是通过动态模块实现的。通过 A 指定备用名称列表文件,在该文件中可以找到动态模块的内核地址
-b 避免 lsof 因调用可能阻塞的内核函数而产生阻塞,比如 lstat(2)、readlink(2) 和 stat(2) 等内核函数
-c C 显示出以字符或字符串 C 开头的命令程序开启的文件,如 lsof -c init。如果 C 以斜杠 / 开头和结尾,则斜杠之间的字符被解释为正则表达式。该选项可多次指定
+c W 指定 COMMAND 列的宽度,单位字符。默认为 9
-C 禁用从内核的名称缓存中报告任何路径名
-D D指导 lsof 使用设备缓存文件。该选项的使用有时受到限制。-D 必须后面跟着一个函数字母,函数字母后面可以有一个路径名称。lsof 识别以下功能字母:? 报告设备缓存文件路径b 构建设备缓存文件i 忽略设备缓存文件r 读取设备缓存文件u 读取并更新设备缓存文件
+D D 递归搜索目录 D。如显示在 /usr/local 及其子目录下被程序开启的文件:lsof +D /usr/local
+d D 非递归搜索目录 D。如显示在 /usr/local 下被程序开启的文件:lsof +d /usr/local
-d FD 指定文件描述符列表,可以采用逗号分隔,也可以指定范围。比如 1,2,3 或 1-3。如果前面包含尖号,表示排除。如显示 FD 为 4 的进程:lsof -d 4
+|-e S 豁免(exempt)路径名称为 S 的文件系统不受可能阻塞的内核函数调用的影响。+e 选项豁免 stat(2)、lstat(2) 和大多数 readlink(2) 内核函数调用。-e 选项只能豁免 stat(2) 和 lstat(2) 内核函数调用
+|-E +E 指定使用端点信息显示 Linux 管道、Linux UNIX 套接字和 Linux 伪终端文件,并显示端点的文件。-E 则不显示端点的文件
-F LIST 指定字符列表 LIST,选择输出给另一程序处理的字段,各字段对应的字符见下文
+|-f [cfgGn]
f 本身澄清了路径名参数的解释方式。当后面跟着 c、f、g、G 或 n 时,它指定要启用(+)或抑制(-)内核文件结构信息。c 文件结构使用计数(not Linux)f 文件结构地址(not Linux)g 文件标志缩写(Linux 2.6.22 及更高版本)G 十六进制文件标志(Linux 2.6.22 及更高版本)n 文件结构节点地址(not Linux)
-g [PGID]选择或排除属于指定进程组的进程打开的文件。 进程组 ID 使用逗号分隔,如果 PGID 前面包含尖号,表示排除。若没有指定 PGID,则显示全部。如显示 PGID 为 6 和 7 的进程:lsof -g6,7
-i [I]选择其 Internet 地址与 -i 中指定的地址匹配的文件,若没有相关地址被指定,则监听全部。用法: lsof -i [46][protocol][@hostname|hostaddr][:serivce|port]说明:4 6 分别表示 IPv4 和 IPv6 protocol: TCP or UDP hostname:主机名hostaddr:IPv4 或 IPv6 地址service:主机提供的服务的名称,即 /etc/services 中的 service nameport:端口号
-K 在支持任务(线程)报告方式的系统上输出进程的任务(线程)列表
-k K 指定内核名称列表文件,代替 /vmunix、/mach 等
-l 禁止将 user ID 转换为登录的名称,默认是登录名称
+|-m M -m 指定一个内核内存文件 M ,代替 /dev/kmem 或 /dev/mem。+m 将装载补充文件写入标准输出文件
+|-M 启用或禁用报告本地 TCP、UDP 和 UDPLITE 端口的端口映射器注册
-n 不将 IP 地址转换为主机名
-N 显示 NFS 文件
-o 始终显示文件偏移量。它导致 SIZE/OFF 输出列标题更改为 OFFSET
-o O 指定在文件偏移量的 0t 之后要打印的小数位数
-O 指示 lsof 避免被某些内核操作阻塞。即在分叉的子进程中执行它们。虽然使用此选项将减少 lsof 启动开销,但也可能导致 lsof 在内核不响应函数时挂起。谨慎使用此选项
-P 禁止将网络文件的端口号转换为端口名
-p S 排除或选择进程的文件列表,进程 ID 列表使用逗号分隔,如 123 或 123,^456。尖号表示排除指定 PID
-R 使用列 PPID 列出父进程的 PID
+|-r [T[mFMT]]
控制 lsof 不断重复执行,间隔 T 秒,默认为 15s。-r 永远不断地执行,直到收到中断讯号(ctrl+ c),+r 一直执行,直到没有文件被显示。可选的 mFMT 参数指定标记线的格式,格式 FMT 遵循 C 语言标准库函数 strftime(3) 的规范
-S [T] 指定内核函数 lstat(2)、readlink(2) 和 stat(2) 的可选超时秒值,否则可能会死锁。t 的最小值是 2;默认值是 15
-s [P:S] 列出文件的大小,若该文件没有大小,则留下空白。它导致 SIZE/OFF 输出列标题更改为 SIZE。P 表示协议名称 TCP or UDP,S 表示逗号分隔的协议状态
-T [T]-T 没有参数则禁用 TCP/TPI 信息报告。跟如下参数,则显示指定 TCP/TPI 信息:f 选择报告套接字选项,状态和值,以及 TCP标志和值q 选择队列长度s 选择连接状态w 选择窗口大小
-t 生成只有进程标识符而没有标题的简洁输出,这样输出可以通过管道传递给 kill(1) 杀死
-U 选择 UNIX 域套接字文件的列表
-u USERS 选择登录名或用户 ID 位于逗号分隔集 USERS 中的用户的文件列表。如 root 或 548,root”,如果用户名或用户 ID 前有尖号 ^,表示排除
-V 指示被要求列出但找不到的项
-v 显示版本信息
+|-w 启用(+)或禁用(-)警告消息
-X Linux 下跳过所有打开的 TCP、UDP 和 UDPLITE IPv4 和 IPv6 文件的信息报告
-x [fl] 一般与选项 +d 和 +D 选项,指示搜索时是否跨文件系统和符号链接。-x 不跟任何参数时,表示跨文件系统和符号链接
-Z [Z] 指定如何处理 SELinux 安全上下文。当在运行的 Linux 内核中禁用SELinux时,Z 字段将被抑制输出。-Z 选项不跟参数,如 -Z -,安全上下文将列在 SECURITY-CONTEXT 列中输出
-- 双减号表示选项结束
NAMES 列出指定文件,符号链接在使用前将被解析
四、示例
[root@192 ~]# lsof | head
COMMAND PID TID USER FD TYPE DEVICE SIZE/OFF NODE NAME
systemd 1 root cwd DIR 253,0 247 64 /
systemd 1 root rtd DIR 253,0 247 64 /
systemd 1 root txt REG 253,0 1616360 67254132 /usr/lib/systemd/systemd
systemd 1 root mem REG 253,0 20112 35006 /usr/lib64/libuuid.so.1.3.0
systemd 1 root mem REG 253,0 265624 35010 /usr/lib64/libblkid.so.1.1.0
systemd 1 root mem REG 253,0 90248 34645 /usr/lib64/libz.so.1.2.7
systemd 1 root mem REG 253,0 157424 35004 /usr/lib64/liblzma.so.5.2.2
systemd 1 root mem REG 253,0 23968 35038 /usr/lib64/libcap-ng.so.0.0.0
systemd 1 root mem REG 253,0 19896 34746 /usr/lib64/libattr.so.1.1.0
COMMAND:进程的名称
PID:进程标识符
TID:任务 ID。Linux 下 TID 为空表示该行为进程
USER:进程所有者
FD:文件描述符。主要有:cwd:应用程序当前工作目录,这是该应用程序启动的目录,除非它本身对这个目录进行更改txt:该类型的文件是程序代码,如应用程序二进制文件本身或共享库,如上列表中显示的 /sbin/init 程序lnn:库引用(AIX)err:FD 信息错误jld:监狱目录(FreeBSD)ltx:共享库文本(代码和数据)mxx:十六进制内存映射类型号 xxm86:DOS合并映射文件mem:内存映射文件mmap:内存映射设备pd:父目录rtd:根目录tr:内核跟踪文件(OpenBSD)v86:VP/ix 映射文件0:标准输出1:标准输入2:标准错误文件描述符后一般还跟着文件状态模式:r:只读模式w:写入模式u:读写模式空格:文件的状态模式为 unknow,且没有锁定-:文件的状态模式为 unknow,且被锁定同时在文件状态模式后面,还跟着相关的锁:N:对于未知类型的 Solaris NFS 锁r:文件部分的读锁R:整个文件的读锁w:文件的部分写锁W:整个文件的写锁u:任何长度的读写锁U:用于未知类型的锁x:用于部分文件上的 SCO OpenServer Xenix 锁X:用于整个文件上的 SCO OpenServer Xenix 锁space:无锁
TYPE:文件类型。常见的文件类型有:REG:普通文件DIR:表示目录CHR:表示字符类型BLK:块设备类型UNIX:UNIX 域套接字FIFO:先进先出队列IPv4:IPv4 套接字
DEVICE:磁盘名称
SIZE:文件的大小或文件偏移量(以字节为单位)
NODE:索引节点
NAME:打开文件的确切名称
2、查看谁正在使用某个文件,也就是说查找某个文件相关的进程。
[root@192 ~]# lsof /bin/bash
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
bash 9380 root txt REG 253,0 964608 100664439 /usr/bin/bash
3、常见参数使用
列出某个用户打开的文件信息。
lsof -u root
列出某个进程所打开的文件信息。
lsof -c sshd
列出多个进程打开的文件信息。
lsof -c mysql -c apache
列出某个用户以及某个进程所打开的文件信息。
lsof -u test -c mysql
通过某个进程号显示该进程打开的文件。
lsof -p 1
列出所有的网络连接。
lsof -i
列出所有的 TCP 网络连接信息。
lsof -i tcp
列出所有 UDP 网络连接信息。
lsof -i udp
列出谁在使用某个端口。
lsof -i :80
列出某个用户的所有活跃的网络端口。
lsof -a -u test -i
列出所有网络文件系统。
lsof -N
选择 UNIX 域套接字文件的列表。
lsof -U
查看某个用户组所打开的文件信息。
lsof -g 5555
根据指定文件描述符的文件信息。
lsof -d txt
查看指定文件描述符范围的文件信息。
lsof -d 2-3
列出被进程号为 1234 的进程所打开的所有 IPV4 网络文件。
lsof -p 1234 -a -i 4