概述
lsof
(List Open Files)是一款在类Unix操作系统(如Linux、BSD和macOS)中使用的强大命令行工具。它用于列出当前系统上所有打开的文件。由于在类Unix系统中,几乎所有东西都被当作文件来处理,lsof
不仅可以显示常规文件,还可以显示网络套接字、管道、设备文件等。
lsof 查看的打开文件可以是
普通文件
目录
字符或块设备文件
共享库
管道、命名管道
符号链接
网络文件(如 NFS file、网络 socket,Unix 域名 socket)
其它类型的文件,等等
安装lsof
在大多数Linux发行版中,lsof
通常默认安装。如果未安装,可以使用以下包管理器进行安装:
Debian/Ubuntu系统
sudo apt-get install lsof
Red Hat/CentOS系统
lsof的基本用法
运行lsof
命令会列出所有当前系统上打开的文件。由于这通常会生成大量输出,因此需要使用一些选项来过滤和查找特定的信息。
列出特定文件的打开情况
lsof /path/to/file

查找使用特定端口的进程
lsof -i :8080

查找特定用户打开的文件
lsof -u lighthouse

查找特定进程ID (PID) 打开的文件
lsof -p 1234

查找网络连接
lsof -i

查找特定类型的文件
lsof -a -d DIR
高级用法
组合选项
lsof
允许组合多个选项来精确定位所需的信息。例如,查找用户root打开的所有网络连接:

输出格式
lsof
的输出包含多个字段,例如:
可以使用管道和其他命令(如grep、awk)进一步处理lsof
的输出。
实用示例
查找并杀死占用端口的进程
假设端口8080被占用,可以使用以下命令查找并杀死占用该端口的进程:
lsof -i :8080

获取进程ID后,使用kill
命令:
查找所有挂载的文件系统上的打开文件
要查找所有挂载的文件系统上的打开文件,可以使用+D选项:
lsof +D /data

总结
lsof
是一个非常强大且灵活的工具,可以帮助系统管理员和开发人员轻松地查看系统上打开的文件和网络连接。通过掌握其基本和高级用法,用户可以有效地监控和管理系统资源。
蓝队云官网上拥有完善的技术支持库可供参考,大家可自行查阅,更多技术问题,可以直接咨询。同时,蓝队云整理了运维必备的工具包免费分享给大家使用,需要的朋友可以直接咨询。更多技术知识,蓝队云期待与你一起探索。