linux命令学习笔记(51):lsof命令
lsof(list open files)是一个列出当前系统打开文件的工具。在linux环境下,任何事物都以文件的形式存在,
通过文件不仅仅可以访问常规数据,还可以访问网络连接和硬件。所以如传输控制协议 (TCP) 和用户数据报协议
(UDP) 套接字等,系统在后台都为该应用程序分配了一个文件描述符,无论这个文件的本质如何,该文件描述符
为应用程序与基础操作系统之间的交互提供了通用接口。因为应用程序打开文件的描述符列表提供了大量关于
这个应用程序本身的信息,因此通过lsof工具能够查看这个列表对系统监测以及排错将是很有帮助的。
.命令格式:
lsof [参数][文件]
.命令功能:
用于查看你进程开打的文件,打开文件的进程,进程打开的端口(TCP、UDP)。找回/恢复删除的文件。是十分方
便的系统监视工具,因为 lsof 需要访问核心内存和各种文件,所以需要root用户执行。
lsof打开的文件可以是:
.普通文件
.目录
.网络文件系统的文件
.字符或设备文件
.(函数)共享库
.管道,命名管道
.符号链接
.网络文件(例如:NFS file、网络socket,unix域名socket)
.还有其它类型的文件,等等
.命令参数:
-a 列出打开文件存在的进程
-c<进程名> 列出指定进程所打开的文件
-g 列出GID号进程详情
-d<文件号> 列出占用该文件号的进程
+d<目录> 列出目录下被打开的文件
+D<目录> 递归列出目录下被打开的文件
-n<目录> 列出使用NFS的文件
-i<条件> 列出符合条件的进程。(、、协议、:端口、 @ip )
-p<进程号> 列出指定进程号所打开的文件
-u 列出UID号进程详情
-h 显示帮助信息
-v 显示版本信息
.使用实例:
实例1:无任何参数
命令:
lsof
输出:
[root@localhost ~]# lsof 复制代码
COMMAND PID USER FD TYPE DEVICE SIZE NODE NAME
init root cwd DIR , /
init root rtd DIR , /
init root txt REG , /sbin/init
init root mem REG , /lib64/ld-2.5.so
init root mem REG , /lib64/libc-2.5.so
init root mem REG , /lib64/libdl-2.5.so
init root mem REG , /lib64/libselinux.so.
init root mem REG , /lib64/libsepol.so.
init root 10u FIFO , /dev/initctl
migration root cwd DIR , /
migration root rtd DIR , /
migration root txt unknown /proc//exe
ksoftirqd root cwd DIR , /
ksoftirqd root rtd DIR , /
ksoftirqd root txt unknown /proc//exe
migration root cwd DIR , /
migration root rtd DIR , /
migration root txt unknown /proc//exe
ksoftirqd root cwd DIR , /
ksoftirqd root rtd DIR , /
ksoftirqd root txt unknown /proc//exe
events/ root cwd DIR , /
events/ root rtd DIR , /
events/ root txt unknown /proc//exe
events/ root cwd DIR , /
复制代码
说明:
lsof输出各列信息的意义如下:
COMMAND:进程的名称
PID:进程标识符
PPID:父进程标识符(需要指定-R参数)
USER:进程所有者
PGID:进程所属组
FD:文件描述符,应用程序通过文件描述符识别该文件。如cwd、txt等
()cwd:表示current work dirctory,即:应用程序的当前工作目录,这是该应用程序启动的目录,
除非它本身对这个目录进行更改
()txt :该类型的文件是程序代码,如应用程序二进制文件本身或共享库,如上列表中显示的 /sbin/init 程序
()lnn:library references (AIX);
()er:FD information error (see NAME column);
()jld:jail directory (FreeBSD);
()ltx:shared library text (code and data);
()mxx :hex memory-mapped type number xx.
()m86:DOS Merge mapped file;
()mem:memory-mapped file;
()mmap:memory-mapped device;
()pd:parent directory;
()rtd:root directory;
()tr:kernel trace file (OpenBSD);
()v86 VP/ix mapped file;
():表示标准输出
():表示标准输入
():表示标准错误
一般在标准输出、标准错误、标准输入后还跟着文件状态模式:r、w、u等
()u:表示该文件被打开并处于读取/写入模式
()r:表示该文件被打开并处于只读模式
()w:表示该文件被打开并处于
()空格:表示该文件的状态模式为unknow,且没有锁定
()-:表示该文件的状态模式为unknow,且被锁定
同时在文件状态模式后面,还跟着相关的锁
()N:for a Solaris NFS lock of unknown type;
()r:for read lock on part of the file;
()R:for a read lock on the entire file;
()w:for a write lock on part of the file;(文件的部分写锁)
()W:for a write lock on the entire file;(整个文件的写锁)
()u:for a read and write lock of any length;
()U:for a lock of unknown type;
()x:for an SCO OpenServer Xenix lock on part of the file;
()X:for an SCO OpenServer Xenix lock on the entire file;
()space:if there is no lock.
TYPE:文件类型,如DIR、REG等,常见的文件类型
()DIR:表示目录
()CHR:表示字符类型
()BLK:块设备类型
()UNIX: UNIX 域套接字
()FIFO:先进先出 (FIFO) 队列
()IPv4:网际协议 (IP) 套接字
DEVICE:指定磁盘的名称
SIZE:文件的大小
NODE:索引节点(文件在磁盘上的标识)
NAME:打开文件的确切名称
实例2:查看谁正在使用某个文件,也就是说查找某个文件相关的进程
命令:
lsof /bin/bash
输出:
复制代码
[root@localhost ~]# lsof /bin/bash
COMMAND PID USER FD TYPE DEVICE SIZE NODE NAME
bash root txt REG , /bin/bash
bash root txt REG , /bin/bash
bash root txt REG , /bin/bash
[root@localhost ~]#
复制代码 说明:
实例3:递归查看某个目录的文件信息
命令:
lsof test/test3
输出:
复制代码
[root@localhost ~]# cd /opt/soft/
[root@localhost soft]# lsof test/test3
COMMAND PID USER FD TYPE DEVICE SIZE NODE NAME
bash root cwd DIR , test/test3
vi root cwd DIR , test/test3
[root@localhost soft]#
复制代码 说明:
使用了+D,对应目录下的所有子目录和文件都会被列出
实例4:不使用+D选项,遍历查看某个目录的所有文件信息的方法
命令:
lsof |grep 'test/test3'
输出:
[root@localhost soft]# lsof |grep 'test/test3'
bash root cwd DIR , /opt/soft/test/test3
vi root cwd DIR , /opt/soft/test/test3
vi root 4u REG , /opt/soft/test/test3/.log2013.log.swp
[root@localhost soft]#
说明:
实例5:列出某个用户打开的文件信息
命令:
lsof -u username
说明:
-u 选项,u其实是user的缩写
实例6:列出某个程序进程所打开的文件信息
命令:
lsof -c mysql
说明:
-c 选项将会列出所有以mysql这个进程开头的程序的文件,其实你也可以写成 lsof | grep mysql,
但是第一种方法明显比第二种方法要少打几个字符了
实例7:列出多个进程多个打开的文件信息
命令:
lsof -c mysql -c apache
实例8:列出某个用户以及某个进程所打开的文件信息
命令:
lsof -u test -c mysql
说明:
用户与进程可相关,也可以不相关
实例9:列出除了某个用户外的被打开的文件信息
命令:
lsof -u ^root
说明:
^这个符号在用户名之前,将会把是root用户打开的进程不让显示
实例10:通过某个进程号显示该进行打开的文件
命令:
lsof -p
实例11:列出多个进程号对应的文件信息
命令:
lsof -p ,,
实例12:列出除了某个进程号,其他进程号所打开的文件信息
命令:
lsof -p ^
实例13:列出所有的网络连接
命令:
lsof -i
实例14:列出所有tcp 网络连接信息
命令:
lsof -i tcp
实例15:列出所有udp网络连接信息
命令:
lsof -i udp
实例16:列出谁在使用某个端口
命令:
lsof -i :
实例17:列出谁在使用某个特定的udp端口
命令:
lsof -i udp:
或者:特定的tcp端口
命令:
lsof -i tcp:
实例18:列出某个用户的所有活跃的网络端口
命令:
lsof -a -u test -i
实例19:列出所有网络文件系统
命令:
lsof -N
实例20:域名socket文件
命令:
lsof -u
实例21:某个用户组所打开的文件信息
命令:
lsof -g
实例22:根据文件描述列出对应的文件信息
命令:
lsof -d description(like )
例如:lsof -d txt
例如:lsof -d
例如:lsof -d
说明:
0表示标准输入,1表示标准输出,2表示标准错误,从而可知:所以大多数应用程序所打开的文件的 FD
都是从 开始
实例23:根据文件描述范围列出文件信息
命令:
lsof -d -
实例24:列出COMMAND列中包含字符串" sshd",且文件描符的类型为txt的文件信息
命令:
lsof -c sshd -a -d txt
输出:
复制代码
[root@localhost soft]# lsof -c sshd -a -d txt
COMMAND PID USER FD TYPE DEVICE SIZE NODE NAME
sshd root txt REG , /usr/sbin/sshd
sshd root txt REG , /usr/sbin/sshd
sshd root txt REG , /usr/sbin/sshd
sshd root txt REG , /usr/sbin/sshd
[root@localhost soft]#
[root@localhost soft]#
复制代码 实例25:列出被进程号为1234的进程所打开的所有IPV4 network files
命令:
lsof -i -a -p
实例26:列出目前连接主机peida.linux上端口为:,,,,,80相关的所有文件信息,
且每隔3秒不断的执行lsof指令
命令:
lsof -i @peida.linux:,,,,, -r
linux命令学习笔记(51):lsof命令的更多相关文章
- linux命令学习笔记( 2 ) : cd 命令
Linux cd 命令可以说是Linux中最基本的命令语句,其他的命令语句要进行操作,都是建立在使用 cd 命令上的. 所以,学习Linux 常用命令,首先就要学好 cd 命令的使用方法技巧. . 命 ...
- linux命令学习笔记( 7 ) : mv 命令
mv命令是move的缩写,可以用来移动文件或者将文件改名(move (rename) files),是Linux系统下常用的命令, 经常用来备份文件或者目录. .命令格式: mv [选项] 源文件或目 ...
- Linux基础学习笔记以及常用命令
1.windows自带命令进入mysql所在磁盘 2.进入mysql安装目录的bin文件 D:\>cd D:\Program Files (x86)\mysql-5.5.25-winx64\ ...
- linux命令学习笔记(62)-curl命令-url下载工具
linux curl是一个利用URL规则在命令行下工作的文件传输工具.它支持文件的上传和下载,所以是综合 传输工具,但按传统,习惯称url为下载工具. 一,curl命令参数,有好多我没有用过,也不知道 ...
- Linux命令学习笔记目录
Linux命令学习笔记目录 最近正在使用,linux,顺便将用到的命令整理了一下. 一. 文件目录操作命令: 0.linux命令学习笔记(0):man 命令 1.linux命令学习笔记(1):ls命令 ...
- linux基础命令学习笔记(二)
linux基础命令学习笔记(二) 1.kill :终止进程 kill pid (唯一标示一个进程) kill -9 强制终止 kill -15 命令未结束不能终止 # ps aux 查看所有进程 ...
- linux命令学习笔记(25):linux文件属性详解
Linux 文件或目录的属性主要包括:文件或目录的节点.种类.权限模式.链接数量.所归属的用户和用户组. 最近访问或修改的时间等内容.具体情况如下: 命令: ls -lih 输出: [root@loc ...
- 【Redis】命令学习笔记——键(key)(20个超全字典版)
安装完redis和redis-desktop-manager后,开始学习命令啦!本篇基于redis 4.0.11版本,从对键(key)开始挖坑! 准备工作,使用db1(默认db0,由于之前练习用db0 ...
- 学习笔记之shell命令
linux shell命令学习笔记:~这里只是对自己一些常用但是不熟悉的的命令进行记录 -------------------------------------------------------- ...
- Oracle学习笔记三 SQL命令
SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)
随机推荐
- 关于PM的认识
1 我眼中的PM 1.1 人云“一个管理,半个专家”,我说“一个管理,两个专家” 如今,我发现我们不得不面对这样一个现实——角色兼职.我习惯上把项目分为三类:性命攸关的项目(涉及到人身安全的项目,如铁 ...
- Html5 meta 笔记
摘抄:原文地址:http://www.kmapk.com/html/help/02/127.html 一.天猫 <title>天猫触屏版</title> <meta co ...
- 开始nodejs+express的学习+实践(1)
开始nodejs+express的学习+实践(1) 开始nodejs+express的学习+实践(2) 开始nodejs+express的学习+实践(3) 开始nodejs+express的学习+实践 ...
- 牛牛有一个鱼缸。鱼缸里面已经有n条鱼,每条鱼的大小为fishSize[i] (1 ≤ i ≤ n,均为正整数),牛牛现在想把新捕捉的鱼放入鱼缸。鱼缸内存在着大鱼吃小鱼的定律。经过观察,牛牛发现一条鱼A的大小为另外一条鱼B大小的2倍到10倍(包括2倍大小和10倍大小),鱼A会吃掉鱼B。考虑到这个,牛牛要放入的鱼就需要保证:1、放进去的鱼是安全的,不会被其他鱼吃掉 2、这条鱼放进去也不能吃掉其他鱼
// ConsoleApplication5.cpp : 定义控制台应用程序的入口点. // #include<vector> #include<algorithm> #inc ...
- Volley框架载入网络图片
Android开发中,载入网络server的图片是非经常常使用的.当然我们能够自己写server接口去实现,只是要做到server性能 优越的话,开发起来比較麻烦点.所以本博客要介绍Volley框架进 ...
- 【转载】【selenium+Python WebDriver】之元素定位
总结: 感谢: “煜妃”<Selenuim+Python之元素定位总结及实例说明> “Huilaojia123”<selenium WebDriver定位元素学习总结> “上海 ...
- 【bootstrap】右侧sidebar不跟着内容滚动的异常
移动开发需要依赖于Web服务的接口,但是写这个接口文档实在是比较繁琐,所以今天我就写了个包解析程序自动生成接口文档. 内容显示我是借鉴Bootstrap的官方教程http://v3.bootcss.c ...
- c 字符串 函数
c编辑 strcpy 原型:extern char *strcpy(char *dest,char *src); 用法:#include <string.h> 功能:把src所指由NUL结 ...
- 漫反射和Lambert模型
粗糙的物体表面向各个方向等强度地反射光,这种等同地向各个方向散射的现象称为光的漫反射(diffuse reflection).产生光的漫反射现象的物体表面称为理想漫反射体,也称为朗伯(Lambert) ...
- Quart 2D 绘制图形简单总结(转)
0 CGContextRef context = UIGraphicsGetCurrentContext(); 设置上下文 1 CGContextMoveToPoint 开始画线 2 CGConte ...