centos8平台使用lsof

纵饮孤独 提交于 2020-04-05 21:23:21

一,lsof的用途

lsof,List Open Files 列出当前系统打开文件的工具。

在linux环境下,任何事物都以文件的形式存在,

所以lsof通过文件不仅仅可以访问常规数据,还可以访问网络连接和硬件

 

说明:刘宏缔的架构森林是一个专注架构的博客,地址:https://www.cnblogs.com/architectforest

         对应的源码可以访问这里获取: https://github.com/liuhongdi/

 说明:作者:刘宏缔 邮箱: 371125307@qq.com

 

二,lsof安装:

1,查看lsof所属的包

[root@blog ~]# whereis lsof
lsof: /usr/bin/lsof /usr/share/man/man1/lsof.1.gz

[root@blog ~]# rpm -qf /usr/bin/lsof
lsof-4.91-2.el8.x86_64

 

2,如果提示找不到lsof命令,可以用yum安装

[root@blog ~]# yum install lsof

 

三,查看lsof的版本和帮助

1,查看版本

[root@blog ~]# lsof -v
lsof version information:
    revision: 4.91...

 

2,查看帮助:

[root@blog ~]# lsof -h 

 

四,lsof的应用例子:

1,查看系统中所有打开的文件

[root@blog ~]# lsof

 

2,查看某个用户打开的文件

# -u 参数用来指定要查看的用户

[root@blog ~]# lsof -u mysql
COMMAND     PID  USER   FD      TYPE             DEVICE   SIZE/OFF      NODE NAME
mysqld_sa 17246 mysql  cwd       DIR              253,1        129 201372497 /usr/local/soft/mysql
mysqld_sa 17246 mysql  rtd       DIR              253,1        272       128 /
mysqld_sa 17246 mysql  txt       REG              253,1    1219216  16999680 /usr/bin/bash 
...

 

3,查看有哪些进程正在打开某个文件?

[root@blog ~]# lsof /data/mysql/log/mysql-slow.log
COMMAND   PID  USER   FD   TYPE DEVICE SIZE/OFF     NODE NAME
mysqld  17700 mysql   29w   REG  253,1    11018 34357947 /data/mysql/log/mysql-slow.log

说明:lsof后加文件名即可列出正在打开文件的进程

 

4,列出某个进程正在打开的文件(最常用的用法)

# -p 指定要查看的进程

[root@blog ~]# lsof -p 17700
COMMAND   PID  USER   FD      TYPE             DEVICE   SIZE/OFF      NODE NAME
mysqld  17700 mysql  cwd       DIR              253,1       4096 302055050 /data/mysql/data
mysqld  17700 mysql  rtd       DIR              253,1        272       128 /
mysqld  17700 mysql  txt       REG              253,1 1078700088 218133053 /usr/local/soft/mysql/bin/mysqld
mysqld  17700 mysql  DEL       REG               0,17              3207767 /[aio]
mysqld  17700 mysql  DEL       REG               0,17              3207766 /[aio]
mysqld  17700 mysql  DEL       REG               0,17              3207765 /[aio]
mysqld  17700 mysql  DEL       REG               0,17              3207764 /[aio] 
...

说明:

 

输出字段的说明:

FD 表示文件描述符号:

如果值是3w,表示:它的文件描述符是 3 号,而 3 后面的 w ,表示以写的方式打开

TYPE 表示文件类型

NAME 表示文件路径

 

5,列出多个进程正在打开的文件(最常用的用法)

[root@blog ~]# lsof -p 7492,7493,7494 

 

6,列出所有的网络连接

# -i 用来查看网络连接的进程

[root@blog ~]# lsof -i
COMMAND     PID   USER   FD   TYPE  DEVICE SIZE/OFF NODE NAME
NetworkMa   834   root   18u  IPv4   21344      0t0  UDP blog:bootpc
nginx      7491   root   22u  IPv4 3087363      0t0  TCP *:http (LISTEN)
nginx      7491   root   23u  IPv4 3087364      0t0  TCP *:54321 (LISTEN)
nginx      7492  nginx   22u  IPv4 3087363      0t0  TCP *:http (LISTEN) 

 

7,指定的连接的类型:

列出所有tcp 网络连接信息

[root@blog ~]# lsof -i tcp

 

列出所有udp 网络连接信息

[root@blog ~]# lsof -i udp

 

8,列出在使用某个端口的进程

#  -i :port用来指定要查看的端口

[root@blog ~]# lsof -i :3306
COMMAND   PID  USER   FD   TYPE  DEVICE SIZE/OFF NODE NAME
mysqld  17700 mysql   31u  IPv6 3206926      0t0  TCP *:mysql (LISTEN)

 

9,列出nginx进程现在打开的文件

# -c 指定要查看的进程的名字

[root@blog ~]# lsof -c nginx

 

10,-n参数:不将IP转换为hostname,默认会进行转换,即默认不加上-n参数,

[root@blog ~]# lsof -n -i :3306
COMMAND   PID  USER   FD   TYPE  DEVICE SIZE/OFF NODE NAME
mysqld  17700 mysql   31u  IPv6 3206926      0t0  TCP *:mysql (LISTEN)

 

11,列出所有使用fd为指定值的进程

# -d:指定文件描述符的值

[root@blog ~]# lsof -d 1 
COMMAND     PID           USER   FD   TYPE             DEVICE SIZE/OFF     NODE NAME
systemd       1           root    1u   CHR                1,3      0t0    11236 /dev/null
systemd-j   513           root    1w   CHR                1,3      0t0    11236 /dev/null 

 

 五,查看centos的版本:

[root@blog ~]# cat /etc/redhat-release
CentOS Linux release 8.0.1905 (Core) 

 

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!