lsof命令的作用
- 用于查看你进程开打的文件,打开文件的进程,进程打开的端口(TCP、UDP)。找回/恢复删除的文件。是十分方便的系统监视工具,因为 lsof 需要访问核心内存和各种文件,所以需要root用户执行。
lsof详解
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
mysqld 1180 mysql cwd DIR 253,0 4096 262249 /var/lib/mysql
mysqld 1180 mysql rtd DIR 253,0 4096 2 /
mysqld 1180 mysql txt REG 253,0 85349440 788926 /usr/sbin/mysqld
mysqld 1180 mysql mem REG 253,0 65928 655389 /lib64/libnss_files-2.12.so
mysqld 1180 mysql mem REG 253,0 469528 655366 /lib64/libfreebl3.so
mysqld 1180 mysql mem REG 253,0 1921176 655373 /lib64/libc-2.12.so
mysqld 1180 mysql mem REG 253,0 90880 655489 /lib64/libgcc_s-4.4.7-20120601.so.1
mysqld 1180 mysql mem REG 253,0 596272 655381 /lib64/libm-2.12.so
mysqld 1180 mysql mem REG 253,0 987096 787788 /usr/lib64/libstdc++.so.6.0.13
mysqld 1180 mysql mem REG 253,0 19536 655379 /lib64/libdl-2.12.so
mysqld 1180 mysql mem REG 253,0 40400 655377 /lib64/libcrypt-2.12.so
mysqld 1180 mysql mem REG 253,0 43880 655401 /lib64/librt-2.12.so
mysqld 1180 mysql mem REG 253,0 3944 655374 /lib64/libaio.so.1.0.1
mysqld 1180 mysql mem REG 253,0 142640 655397 /lib64/libpthread-2.12.so
mysqld 1180 mysql mem REG 253,0 154624 655363 /lib64/ld-2.12.so
mysqld 1180 mysql 0r CHR 1,3 0t0 3782 /dev/null
mysqld 1180 mysql 1w REG 253,0 684315 262288 /var/lib/mysql/localhost.localdomain.err
mysqld 1180 mysql 2w REG 253,0 684315 262288 /var/lib/mysql/localhost.localdomain.err
mysqld 1180 mysql 3uW REG 253,0 79691776 262381 /var/lib/mysql/ibdata1
mysqld 1180 mysql 4u REG 253,0 0 1966087 /tmp/ibBOOuA6 (deleted)
mysqld 1180 mysql 5u REG 253,0 0 1966092 /tmp/ibX6N8u1 (deleted)
mysqld 1180 mysql 6u REG 253,0 0 1966093 /tmp/ibqGaNpW (deleted)
mysqld 1180 mysql 7u REG 253,0 0 1966094 /tmp/ibuLnlDM (deleted)
mysqld 1180 mysql 8uW REG 253,0 50331648 262466 /var/lib/mysql/ib_logfile0
mysqld 1180 mysql 9uW REG 253,0 50331648 262467 /var/lib/mysql/ib_logfile1
mysqld 1180 mysql 10uW REG 253,0 98304 263215 /var/lib/mysql/mysql/innodb_index_stats.ibd
mysqld 1180 mysql 11u REG 253,0 0 1966107 /tmp/ibT8BG4I (deleted)
mysqld 1180 mysql 12uW REG 253,0 98304 263213 /var/lib/mysql/mysql/innodb_table_stats.ibd
mysqld 1180 mysql 13uW REG 253,0 114688 263548 /var/lib/mysql/qianlong/finance_order.ibd
mysqld 1180 mysql 14uW REG 253,0 180224 263552 /var/lib/mysql/qianlong/pay_record.ibd
mysqld 1180 mysql 15uW REG 253,0 114688 263544 /var/lib/mysql/qianlong/finance_interest.ibd
mysqld 1180 mysql 16u IPv6 11162 0t0 TCP *:mysql (LISTEN)
mysqld 1180 mysql 17u unix 0xffff880019b5e6c0 0t0 11163 /var/lib/mysql/mysql.sock
mysqld 1180 mysql 18u REG 253,0 2048 262472 /var/lib/mysql/mysql/user.MYI
mysqld 1180 mysql 19u REG 253,0 556 262473 /var/lib/mysql/mysql/user.MYD
mysqld 1180 mysql 20u REG 253,0 5120 262469 /var/lib/mysql/mysql/db.MYI
mysqld 1180 mysql 21u REG 253,0 880 262470 /var/lib/mysql/mysql/db.MYD
mysqld 1180 mysql 22u REG 253,0 5120 263277 /var/lib/mysql/mysql/proxies_priv.MYI
mysqld 1180 mysql 23u REG 253,0 1386 263278 /var/lib/mysql/mysql/proxies_priv.MYD
mysqld 1180 mysql 24u REG 253,0 4096 262660 /var/lib/mysql/mysql/tables_priv.MYI
mysqld 1180 mysql 25u REG 253,0 0 262661 /var/lib/mysql/mysql/tables_priv.MYD
mysqld 1180 mysql 26u REG 253,0 4096 262774 /var/lib/mysql/mysql/columns_priv.MYI
mysqld 1180 mysql 27u REG 253,0 0 263157 /var/lib/mysql/mysql/columns_priv.MYD
mysqld 1180 mysql 28u REG 253,0 4096 263198 /var/lib/mysql/mysql/procs_priv.MYI
mysqld 1180 mysql 29u REG 253,0 0 263199 /var/lib/mysql/mysql/procs_priv.MYD
mysqld 1180 mysql 30u REG 253,0 1024 262602 /var/lib/mysql/mysql/servers.MYI
mysqld 1180 mysql 31u REG 253,0 0 262642 /var/lib/mysql/mysql/servers.MYD
- COMMAND 进程的名称
- PID 进程id
- USER 进程所有者
FD 文件描述符
- (1)cwd:表示current work dirctory,即:应用程序的当前工作目录,这是该应用程序启动的目录,除非它本身对这个目录进行更改
- (2)txt :该类型的文件是程序代码,如应用程序二进制文件本身或共享库,如上列表中显示的 /sbin/init 程序
- (3)lnn:library references (AIX);
- (4)er:FD information error (see NAME column);
- (5)jld:jail directory (FreeBSD);
- (6)ltx:shared library text (code and data);
- (7)mxx :hex memory-mapped type number xx.
- (8)m86:DOS Merge mapped file;
- (9)mem:memory-mapped file;
- (10)mmap:memory-mapped device;
- (11)pd:parent directory;
- (12)rtd:root directory;
- (13)tr:kernel trace file (OpenBSD);
- (14)v86 VP/ix mapped file;
- (15)0:表示标准输出
- (16)1:表示标准输入
(17)2:表示标准错误
一般在标准输出、标准错误、标准输入后还跟着文件状态模式:r、w、u等
- (1)u:表示该文件被打开并处于读取/写入模式
- (2)r:表示该文件被打开并处于只读模式
- (3)w:表示该文件被打开并处于
- (4)空格:表示该文件的状态模式为unknow,且没有锁定
- (5)-:表示该文件的状态模式为unknow,且被锁定
- 同时在文件状态模式后面,还跟着相关的锁
- (1)N:for a Solaris NFS lock of unknown type;
- (2)r:for read lock on part of the file;
- (3)R:for a read lock on the entire file;
- (4)w:for a write lock on part of the file;(文件的部分写锁)
- (5)W:for a write lock on the entire file;(整个文件的写锁)
- (6)u:for a read and write lock of any length;
- (7)U:for a lock of unknown type;
- (8)x:for an SCO OpenServer Xenix lock on part of the file;
- (9)X:for an SCO OpenServer Xenix lock on the entire file;
- (10)space:if there is no lock.
TYPE 文件类型
- (1)DIR:表示目录
- (2)CHR:表示字符类型
- (3)BLK:块设备类型
- (4)UNIX: UNIX 域套接字
- (5)FIFO:先进先出 (FIFO) 队列
- (6)IPv4:网际协议 (IP) 套接字
DEVICE 指定磁盘名称
- SIZE/OFF 文件的大小
- NODE 索引节点
- NAME 打开文件的确切的名称
参数详解
- lsof my.cnf 显示开启文件my.cnf的进程
- lsof -c abc 显示abc进程现在打开的文件
- lsof -c -p 1234 列出进程号为1234的进程所打开的文件
- lsof -g gid 显示归属gid的进程情况
- lsof +d /usr/local/ 显示目录下被进程开启的文件
- lsof +D /usr/local/ 同上,但是会搜索目录下的目录,时间较长
- lsof -d 4 显示使用fd为4的进程
- lsof -i 用以显示符合条件的进程情况* lsof -i[46] [protocol][@hostname|hostaddr][:service|port]
46 –> IPv4 or IPv6
protocol –> TCP or UDP
hostname –> Internet host name
hostaddr –> IPv4地址
service –> /etc/service中的 service name (可以不止一个)
port –> 端口号 (可以不止一个)
实例
- lsof
which httpd
//那个进程在使用apache的可执行文件 - lsof /etc/passwd //那个进程在占用/etc/passwd
- lsof /dev/hda6 //那个进程在占用hda6
- lsof /dev/cdrom //那个进程在占用光驱
- lsof -c sendmail //查看sendmail进程的文件使用情况
- lsof -c courier -u ^zahn //显示出那些文件被以courier打头的进程打开,但是并不属于用户zahn
- lsof -p 30297 //显示那些文件被pid为30297的进程打开
lsof -D /tmp 显示所有在/tmp文件夹中打开的instance和文件的进程。但是symbol文件并不在列
lsof -u1000 //查看uid是100的用户的进程的文件使用情况
- lsof -utony //查看用户tony的进程的文件使用情况
- lsof -u^tony //查看不是用户tony的进程的文件使用情况(^是取反的意思)
- lsof -i //显示所有打开的端口
- lsof -i:80 //显示所有打开80端口的进程
- lsof -i -U //显示所有打开的端口和UNIX domain文件
- lsof -i UDP@[url]www.akadia.com:123 //显示那些进程打开了到www.akadia.com的UDP的123(ntp)端口的链接
- lsof -i tcp@ohaha.ks.edu.tw:ftp -r //不断查看目前ftp连接的情况(-r,lsof会永远不断的执行,直到收到中断信号,+r,lsof会一直执行,直到没有档案被显示,缺省是15s刷新)
- lsof -i tcp@ohaha.ks.edu.tw:ftp -n //lsof -n 不将IP转换为hostname,缺省是不加上-n参数
我的应用场景
查找服务的配置文件位置
- ps aux | grep mysql(例如mysql的进程为1234)
- lsof -p 1234
查看端口是否被占用
- lsof -i:9000
恢复被删除文件(网上找的,没用过)
当Linux计算机受到入侵时,常见的情况是日志文件被删除,以掩盖攻击者的踪迹。管理错误也可能导致意外删除重要的文件,比如在清理旧日志时,意外地删除了数据库的活动事务日志。有时可以通过lsof来恢复这些文件。 当进程打开了某个文件时,只要该进程保持打开该文件,即使将其删除,它依然存在于磁盘中。这意味着,进程并不知道文件已经被删除,它仍然可以向打开该文件时提供给它的文件描述符进行读取和写入。除了该进程之外,这个文件是不可见的,因为已经删除了其相应的目录索引节点。 在/proc 目录下,其中包含了反映内核和进程树的各种文件。/proc目录挂载的是在内存中所映射的一块区域,所以这些文件和目录并不存在于磁盘中,因此当我们对这些文件进行读取和写入时,实际上是在从内存中获取相关信息。大多数与 lsof 相关的信息都存储于以进程的 PID 命名的目录中,即 /proc/1234 中包含的是 PID 为 1234 的进程的信息。每个进程目录中存在着各种文件,它们可以使得应用程序简单地了解进程的内存空间、文件描述符列表、指向磁盘上的文件的符号链接和其他系统信息。lsof 程序使用该信息和其他关于内核内部状态的信息来产生其输出。所以lsof 可以显示进程的文件描述符和相关的文件名等信息。也就是我们通过访问进程的文件描述符可以找到该文件的相关信息。 当系统中的某个文件被意外地删除了,只要这个时候系统中还有进程正在访问该文件,那么我们就可以通过lsof从/proc目录下恢复该文件的内容。 假如由于误操作将/var/log/messages文件删除掉了,那么这时要将/var/log/messages文件恢复的方法如下: 首先使用lsof来查看当前是否有进程打开/var/logmessages文件,如下: # lsof |grep /var/log/messages syslogd 1283 root 2w REG 3,3 5381017 1773647 /var/log/messages (deleted) 从上面的信息可以看到 PID 1283(syslogd)打开文件的文件描述符为 2。同时还可以看到/var/log/messages已经标记被删除了。因此我们可以在 /proc/1283/fd/2 (fd下的每个以数字命名的文件表示进程对应的文件描述符)中查看相应的信息,如下: # head -n 10 /proc/1283/fd/2 Aug 4 13:50:15 holmes86 syslogd 1.4.1: restart. Aug 4 13:50:15 holmes86 kernel: klogd 1.4.1, log source = /proc/kmsg started. Aug 4 13:50:15 holmes86 kernel: Linux version 2.6.22.1-8 (root@everestbuilder.linux-ren.org) (gcc version 4.2.0) #1 SMP Wed Jul 18 11:18:32 EDT 2007 Aug 4 13:50:15 holmes86 kernel: BIOS-provided physical RAM map: Aug 4 13:50:15 holmes86 kernel: BIOS-e820: 0000000000000000 - 000000000009f000 (usable) Aug 4 13:50:15 holmes86 kernel: BIOS-e820: 000000000009f000 - 00000000000a0000 (reserved) Aug 4 13:50:15 holmes86 kernel: BIOS-e820: 0000000000100000 - 000000001f7d3800 (usable) Aug 4 13:50:15 holmes86 kernel: BIOS-e820: 000000001f7d3800 - 0000000020000000 (reserved) Aug 4 13:50:15 holmes86 kernel: BIOS-e820: 00000000e0000000 - 00000000f0007000 (reserved) Aug 4 13:50:15 holmes86 kernel: BIOS-e820: 00000000f0008000 - 00000000f000c000 (reserved) 从上面的信息可以看出,查看 /proc/8663/fd/15 就可以得到所要恢复的数据。如果可以通过文件描述符查看相应的数据,那么就可以使用 I/O 重定向将其复制到文件中,如: cat /proc/1283/fd/2 > /var/log/messages 对于许多应用程序,尤其是日志文件和数据库,这种恢复删除文件的方法非常有用。