lsof的使用

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
    对于许多应用程序,尤其是日志文件和数据库,这种恢复删除文件的方法非常有用。
    
坚持原创技术分享,您的支持将鼓励我继续创作!