Linux_Linux指令_lsof 指令

 

参考文章:

1.Linux 命令神器:lsof

https://www.jianshu.com/p/a3aa6b01b2e1

 

2.linux lsof 命令详解

https://www.cnblogs.com/sparkbj/p/7161669.html

 

   lsof是系统管理/安全的尤伯工具。将这个工具称之为lsof真实名副其实,因为它是指“列出打开文件(lists openfiles)”。而有一点要切记,在Unix中一切(包括网络套接口)都是文件。

  有趣的是,lsof也是有着最多开关的Linux/Unix命令之一。它有那么多的开关,它有许多选项支持使用-和+前缀。

 


基础介绍

[root@cdh-manager linux_cmd_test]# lsof -h
lsof 4.87
 latest revision: ftp://lsof.itap.purdue.edu/pub/tools/unix/lsof/
 latest FAQ: ftp://lsof.itap.purdue.edu/pub/tools/unix/lsof/FAQ
 latest man page: ftp://lsof.itap.purdue.edu/pub/tools/unix/lsof/lsof_man
 usage: [-?abhKlnNoOPRtUvVX] [+|-c c] [+|-d s] [+D D] [+|-f[gG]] [+|-e s]
 [-F [f]] [-g [s]] [-i [i]] [+|-L [l]] [+m [m]] [+|-M] [-o [o]] [-p s]
[+|-r [t]] [-s [p:s]] [-S [t]] [-T [t]] [-u s] [+|-w] [-x [fl]] [--] [names]
Defaults in parentheses; comma-separated set (s) items; dash-separated ranges.
  -?|-h list help          -a AND selections (OR)     -b avoid kernel blocks
  -c c  cmd c ^c /c/[bix]  +c w  COMMAND width (9)    +d s  dir s files
  -d s  select by FD set   +D D  dir D tree *SLOW?*   +|-e s  exempt s *RISKY*
  -i select IPv[46] files  -K list tasKs (threads)    -l list UID numbers
  -n no host names         -N select NFS files        -o list file offset
  -O no overhead *RISKY*   -P no port names           -R list paRent PID
  -s list file size        -t terse listing           -T disable TCP/TPI info
  -U select Unix socket    -v list version info       -V verbose search
  +|-w  Warnings (+)       -X skip TCP&UDP* files     -Z Z  context [Z]
  -- end option scan     
  +f|-f  +filesystem or -file names     +|-f[gG] flaGs 
  -F [f] select fields; -F? for help  
  +|-L [l] list (+) suppress (-) link counts < l (0 = all; default = 0)
                                        +m [m] use|create mount supplement
  +|-M   portMap registration (-)       -o o   o 0t offset digits (8)
  -p s   exclude(^)|select PIDs         -S [t] t second stat timeout (15)
  -T qs TCP/TPI Q,St (s) info
  -g [s] exclude(^)|select and print process group IDs
  -i i   select by IPv[46] address: [46][proto][@host|addr][:svc_list|port_list]
  +|-r [t[m<fmt>]] repeat every t seconds (15);  + until no files, - forever.
       An optional suffix to t is m<fmt>; m must separate t from <fmt> and
      <fmt> is an strftime(3) format for the marker line.
  -s p:s  exclude(^)|select protocol (p = TCP|UDP) states by name(s).
  -u s   exclude(^)|select login|UID set s
  -x [fl] cross over +d|+D File systems or symbolic Links
  names  select named files or files on named file systems
Anyone can list all files; /dev warnings disabled; kernel ID check disabled.

 

 

 

可以列出被进程打开文件的信息。被打开的文件可以是

1.普通的文件,

2.目录  

3.网络文件系统的文件,

4.字符设备文件  

5.(函数)共享库  

6.管道,命名管道 

7.符号链接

8.底层的socket字流,网络socket,unix域名socket

9.在linux里面,大部分的东西都是被当做文件的…..还有其他很多

 

 

lsof 的表头信息

COMMAND   PID  USER   FD      TYPE             DEVICE  SIZE/OFF      NODE NAME

COMMAND        进程的名称

PID                    进程标识符

USER                进程所有者

FD                     文件描述符,应用程序通过文件描述符试别该文件。如 cwd. txt 等

TYPE                文件类型,如DIR , REG 等

DEVICE           指定磁盘的名称

SIZE               文件的大小

NODE             索引节点(文件在磁盘的标识)

NAME             打开文件的确切名称

 

 

 

 

lsof的一些使用示例

这里主要用案例的形式来介绍lsof 命令的使用

 

列出所有打开的文件:

lsof

备注: 如果不加任何参数,就会打开所有被打开的文件,建议加上一下参数来具体定位

 

-------------------------------------------------

 

 

查看谁正在使用某个文件

lsof   /filepath/file

 

​​​​​​​-------------------------------------------------

 

 

递归查看某个目录的文件信息

lsof +D /filepath/filepath2/

备注: 使用了+D,对应目录下的所有子目录和文件都会被列出

 

​​​​​​​-------------------------------------------------

 

 

比使用+D选项,遍历查看某个目录的所有文件信息 的方法

lsof | grep ‘/filepath/filepath2/’

 

 

 ​​​​​​​-------------------------------------------------

 

 

列出某个用户打开的文件信息

lsof  -u username

备注: -u 选项,u其实是user的缩写

 

​​​​​​​-------------------------------------------------

 

列出某个进程打开的文件信息

[root@cdh-manager linux_cmd_test]# jps
11872 ThriftServer
12225 RunJar
12097 ResourceManager
11619 RESTServer
33347 JobHistoryServer
13987 Main
12070 HMaster
11751 QuorumPeerMain
13996 EventCatcherService
11726 AlertPublisher
11601 NameNode
11762 Kafka
12213 RunJar
11606 SecondaryNameNode
41852 Jps
9821 Main
14047 Main

看下 Kafka 进程打开了那些文件

[root@cdh-manager linux_cmd_test]# lsof -p 11762 | head
COMMAND   PID  USER   FD      TYPE             DEVICE  SIZE/OFF      NODE NAME
java    11762 kafka  cwd       DIR               0,41       360     57434 /run/cloudera-scm-agent/process/175-kafka-KAFKA_BROKER
java    11762 kafka  rtd       DIR              253,0       235        64 /
java    11762 kafka  txt       REG              253,0      8464   8480337 /opt/java_home/jdk1.8.0_191/bin/java
java    11762 kafka  mem       REG              253,0  10485756  38001682 /var/local/kafka/data/test-topic-2/00000000000000000001.timeindex
java    11762 kafka  mem       REG              253,0  10485760  38001653 /var/local/kafka/data/test-topic-2/00000000000000000001.index
java    11762 kafka  mem       REG              253,0  10485756   8372177 /var/local/kafka/data/test-topic-0/00000000000000000002.timeindex
java    11762 kafka  mem       REG              253,0  10485760   8372176 /var/local/kafka/data/test-topic-0/00000000000000000002.index
java    11762 kafka  mem       REG              253,0  10485756 103851383 /var/local/kafka/data/test-topic-3/00000000000000000001.timeindex
java    11762 kafka  mem       REG              253,0  10485760 103851065 /var/local/kafka/data/test-topic-3/00000000000000000001.index

 

 

​​​​​​​-------------------------------------------------

列出某个程序所打开的文件信息

lsof -c mysql

注意 -c 指定是 cmd 

备注: -c 选项将会列出所有以mysql开头的程序的文件,其实你也可以写成lsof | grep mysql,但是第一种方法明显比第二种方法要少打几个字符了

 

​​​​​​​-------------------------------------------------

 

列出多个程序多打开的文件信息

lsof -c mysql -c apache

 

​​​​​​​-------------------------------------------------

 

列出某个用户以及某个程序所打开的文件信息

lsof -u test -c mysql

 ​​​​​​​

-------------------------------------------------

 

列出除了某个用户外的被打开的文件信息

lsof   -u ^root

备注:^这个符号在用户名之前,将会把是root用户打开的进程不让显示

 

​​​​​​​-------------------------------------------------

 

通过某个进程号显示该进行打开的文件

lsof -p 1

 

​​​​​​​-------------------------------------------------

 

列出多个进程号对应的文件信息

lsof -p 123,456,789

 ​​​​​​

-------------------------------------------------

 

列出除了某个进程号,其他进程号所打开的文件信息

lsof -p ^1

 

​​​​​​​-------------------------------------------------

 

 列出所有的网络连接

lsof -i

 

​​​​​​​-------------------------------------------------

 

列出所有tcp 网络连接信息

lsof  -i tcp

 

​​​​​​​-------------------------------------------------

 

列出所有udp网络连接信息

lsof  -i udp

 

​​​​​​​-------------------------------------------------

 

列出谁在使用某个端口

lsof -i :3306

 

​​​​​​​-------------------------------------------------

 

列出基于某种协议下的某个端口的使用

    udp 55 端口

lsof -i udp:55

   tcp 80 端口

lsof -i tcp:80

 

​​​​​​​-------------------------------------------------

 

列出某个用户的所有活跃的网络端口

lsof  -a -u test -i

 

​​​​​​​-------------------------------------------------

 

列出所有网络文件系统

lsof -N

 

-------------------------------------------------

 

域名socket文件

lsof -u

 

----------------------------------------

 

某个用户组所打开的文件信息

lsof -g 5555

 

------------------------------------------------------

 

 

 根据文件描述列出对应的文件信息

lsof -d description(like 2)

 

------------------------------------------------------

 

根据文件描述范围列出文件信息

lsof -d 2-3

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值