lsof的使用

本文详细介绍了Lsof命令的功能及使用方法,包括如何查看进程打开的文件、筛选特定条件的进程及其打开文件等。Lsof是Unix系统中一个强大的工具,能够帮助管理员和开发者深入了解系统的文件操作情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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:打开文件的确切名称

### 如何在 Linux 中使用 `lsof` 命令查看打开的文件或进程 `lsof` 是一个强大的命令行工具,用于列出系统中打开的文件及其相关信息。在 Linux 系统中,几乎所有内容都被视为文件,因此 `lsof` 不仅可以查看普通文件,还可以查看网络连接、进程信息等。 以下是关于如何使用 `lsof` 查看打开的文件或进程的详细说明: #### 查看所有打开的文件 运行以下命令可以列出当前系统中所有进程打开的文件: ```bash lsof ``` 此命令将显示每个进程及其相关的文件描述符和文件路径[^1]。 #### 根据文件名查找打开的文件 如果需要查找特定文件是否被某个进程打开,可以使用以下命令: ```bash lsof /path/to/file ``` 例如,要检查 `/var/log/syslog` 是否被任何进程占用,可以运行: ```bash lsof /var/log/syslog ``` #### 根据进程 ID 查找打开的文件 可以通过指定进程 ID 来列出该进程打开的所有文件: ```bash lsof -p <PID> ``` 例如,如果进程 ID 为 1234,则运行以下命令: ```bash lsof -p 1234 ``` #### 查找特定用户打开的文件 可以使用 `-u` 参数来列出特定用户打开的所有文件: ```bash lsof -u username ``` 例如,列出用户 `john` 打开的所有文件: ```bash lsof -u john ``` #### 查找特定端口上的网络连接 `lsof` 还可以用于查找占用特定端口的进程。例如,要查找占用 80 端口的进程,可以运行以下命令: ```bash lsof -i :80 ``` 这将列出所有与端口 80 相关的网络连接和进程信息[^2]。 #### 查找已删除但仍在使用的文件 在某些情况下,文件可能已被删除,但仍有进程持有其打开的文件描述符。这些文件仍然占用磁盘空间,直到相关进程释放它们。可以使用以下命令查找此类文件: ```bash lsof | grep "deleted" ``` 此命令将列出所有已删除但仍在使用的文件及其对应的进程 ID[^4]。 #### 示例:恢复已删除但仍在使用的文件 如果发现某个大文件被删除但仍被进程占用,可以通过以下方法恢复该文件: 1. 使用 `lsof` 找到对应的进程 ID 和文件描述符: ```bash lsof | grep "deleted" ``` 2. 将文件内容复制到新位置: ```bash cp /proc/<PID>/fd/<FD> /path/to/newfile ``` #### 注意事项 - 使用 `lsof` 需要超级用户权限(即 `sudo`),因为某些文件和进程信息可能涉及系统级权限。 - `lsof` 的输出可能非常庞大,建议结合 `grep` 或其他过滤工具来缩小范围[^3]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值