Linux shell编程学习笔记47:lsof命令

news/2024/9/20 1:18:42/ 标签: linux, 学习笔记, shell编程, 脚本编程, lsof命令

0 前言

今天国产电脑提示磁盘空间已耗尽,使用用df命令检查文件系统情况,发现/dev/sda2已使用100%。

Linux shell编程学习笔记39:df命令icon-default.png?t=N7T8https://blog.csdn.net/Purpleendurer/article/details/135577571于是开始清理磁盘空间。

第一步是查看已删除、但空间却没有释放的进程。

这里要用到 lsof命令

lsof命令的安装

PurpleEndurer @  bash ~ $ lsof --help
bash: lsof: command not found
PurpleEndurer @  bash ~ $ 

 

lsof 命令默认是没有安装的,如果你的系统中没有安装这个命令,那么可以 使用以下命令安装:

yum install -y lsof

PurpleEndurer @  bash ~ $ yum install -y lsof
Loaded plugins: fastestmirror, ovl
ovl: Error while doing RPMdb copy-up:
[Errno 13] Permission denied: '/var/lib/rpm/Providename'
You need to be root to perform this command.
PurpleEndurer @  bash ~ $ 
 

 

lsof命令的功能、格式和选项说明

我们像往常输入lsof --help命令,想查看 lsof命令的帮助信息。

purpleEndurer @bash ~ $  lsof --help
lsof: illegal option character: -
lsof: -e not followed by a file system path: "lp"
lsof 4.89
 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] [+|-E] [+|-e s] [+|-f[gG]]
 [-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     
  -E display endpoint info              +E display endpoint info and files
  +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.
purpleEndurer @bash ~ $ 
 

尽管 lsof命令不支持--help选项,但给出了帮助信息。

查看 lsof命令 帮助信息正确选项是 -? 或 -h。

2.1 命令功能

lsof 是 List Open File 的缩写, 主要功能是获取和显示被进程打开文件的信息。

2.2 命令格式

lsof [-?abhKlnNoOPRtUvVX] [+|-c c] [+|-d s] [+D D] [+|-E] [+|-e s] [+|-f[gG]]
 [-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]

2.3 选项说明

选项描述
-h显示帮助信息
-aAND选择(默认是或)
-b避免内核块
-c ccmd c ^c /c/[bix]
+c w命令宽度(默认为9)
+d s显示目录集合s下被打开的文件
-d s通过文件描述符(FD)集合s来选择
+D D递归处理所有子文件 *慢?*
+|-e s豁免 s *风险*
-E显示端点信息
+E显示端点信息和文件
+f|-f+文件系统或 -文件名
+|-f[gG]flaGs
-F [f]选择字段;-F?寻求帮助
-g [s]排除(^)或选择并打印进程组ID
-i 按 IPv[46] 地址选择:[46][proto][@host|addr][:svc_list|port_list]
-K列出tasKs(线程)
-l列出UID号
+|-L [l]列表 (+) 抑制 (-) 链路计数 < l (0 = all; default = 0)
+m [m]使用或创建安装补充
+|-M端口映射注册 (-) 
-n没有主机名
-N选择NFS文件列表
-o列出文件偏移量 -o o o 0t 偏移位数(8)
-O无开销 *风险*
-p s排除(^)或选择PIDs -S [t]  t秒统计超时(15)
-P无端口名称
-R列出paRent PID
+-r [t[m<fmt>]]
-s列表文件大小
-s p:s排除(^)或选择protocol(p = TCP|UDP) 按名称表示。
S [t]t 秒统计超时 (默认为15秒)
-t简洁列表
-T禁用TCP/TPI信息
-TqsTCP/TPI Q,St(s)信息
-u s排除(^)或 选择登录 或 UID集s
-U选择Unix套接字
-v显示版本信息
-V详细搜索
+|-w    警告
-x [fl]跨越 +d|+D 文件系统或符号链接
-X跳过TCP&UDP*文件
-Z Z上下文[Z]
--结束选项扫描
name选择命名文件或命名文件系统上的文件
  • 括号中的是默认值
  • 集合项使用逗号分隔
  • 范围使用破折号分隔

3 使用实例

3.1 lsof : 显示当前所有活跃进程打开的所有文件

显示的内容很多,不好截图。

3.2 lsof | more:分页显示显示当前所有活跃进程打开的所有文件

我们可以使用管道操作符和more命令来分实现分页显示

purpleEndurer @bash / $ lsof | more
COMMAND     PID   TID             USER   FD      TYPE             DEVICE  SIZE/OFF       NODE NAME
systemd       1                   root  cwd   unknown                                         /proc/1/cwd (
readlink: Permission denied)
systemd       1                   root  rtd   unknown                                         /proc/1/root 
(readlink: Permission denied)
systemd       1                   root  txt   unknown                                         /proc/1/exe (
readlink: Permission denied)
systemd       1                   root NOFD                                                   /proc/1/fd (o
pendir: Permission denied)
kthreadd      2                   root  cwd   unknown                                         /proc/2/cwd (
readlink: Permission denied)
kthreadd      2                   root  rtd   unknown                                         /proc/2/root 
(readlink: Permission denied)
kthreadd      2                   root  txt   unknown                                         /proc/2/exe (
readlink: Permission denied)
kthreadd      2                   root NOFD                                                   /proc/2/fd (o
pendir: Permission denied)
ksoftirqd     3                   root  cwd   unknown                                         /proc/3/cwd (
readlink: Permission denied)
ksoftirqd     3                   root  rtd   unknown                                         /proc/3/root 
(readlink: Permission denied)
ksoftirqd     3                   root  txt   unknown                                         /proc/3/exe (
readlink: Permission denied)
ksoftirqd     3                   root NOFD                                                   /proc/3/fd (o
pendir: Permission denied)
kworker/0     5                   root  cwd   unknown                                         /proc/5/cwd (
readlink: Permission denied)
kworker/0     5                   root  rtd   unknown                                         /proc/5/root 
(readlink: Permission denied)
 

命令执行后返回的信息默认有10列,说明如下:

1. COMMAND:进程名称

2.PID:进程ID

3.TID:线程ID

4.USER:所属用户

5.FD:文件描述符

可能的类型以及说明如下:

FD说明
cwd当前目录
txttxt文件
rtdroot目录
mem内存映射文件

6. TYPE:文件类型

可能的值以及说明如下:

TYPE说明
DIR目录
REG普通文件
CHR字符
a_inodeInode文件
FIFO管道或者socket文件
netlink网络
unknown未知

7.DEVICE:设备ID

8. SIZE/OFF:进程大小

9.NODE:文件的Inode号

10.NAME:路径或者链接

后面备注(readlink: Permission denied),是因为当前用户相应的访问权限。

所以使用lsof命令最好有root权限或者赋予普通用于sudo权限。

3.3 lsof +d proc:显示当前目录下的proc目录中被打开的文件信息

purpleEndurer @bash / $ lsof +d proc | more
COMMAND     PID USER   FD   TYPE DEVICE SIZE/OFF       NODE NAME
systemd    2641 gxxc   12r   REG    0,4        0 4026531994 proc/swaps
lsof      12178 gxxc    3r   DIR    0,4        0          1 proc
qaxbrowse 14744 gxxc   12r   DIR    0,4        0          1 proc
qaxbrowse 14770 gxxc   19r   DIR    0,4        0          1 proc
purpleEndurer @bash / $ 

 

3.4 lsof +d proc +l:显示当前目录下的proc目录中被打开的文件信息,其中USER列不显示用户名而显示UID

purpleEndurer @bash / $ lsof +d proc -l | more
COMMAND     PID     USER   FD   TYPE DEVICE SIZE/OFF       NODE NAME
systemd    2641     1000   12r   REG    0,4        0 4026531994 proc/swaps
qaxbrowse 14744     1000   12r   DIR    0,4        0          1 proc
qaxbrowse 14770     1000   19r   DIR    0,4        0          1 proc
lsof      14916     1000    3r   DIR    0,4        0          1 proc
purpleEndurer @bash / $ 

由于我们使用了 -l选项,所以执行结果中USER列显示的1000是UID


http://www.ppmy.cn/news/1433423.html

相关文章

服务器防入侵的方案浅析

随着物联网技术和互联网技术的日益发展&#xff0c;勒索病毒、工控安全、产线作业都面领着极大的威胁。智慧互联正在成为各个行业未来的发展方向&#xff0c;智慧互联包括物联网、万物互联&#xff0c;机器与机器&#xff0c;工业控制体系&#xff0c;信息化&#xff0c;也就是…

XiaodiSec day007 Learn Note 小迪安全学习笔记

XiaodiSec day007 Learn Note 小迪安全学习笔记 记录得比较凌乱&#xff0c;不尽详细 07 2023.12.31 cms识别 资产泄漏&#xff0c;资产即为网站的资源&#xff0c;了解到网站使用了那种cms对信息收集很有帮助 使用工具识别cms 识别cms后可以进行代码审计&#xff0c;或…

【RAG 论文】面向知识库检索进行大模型增强的框架 —— KnowledGPT

论文&#xff1a;KnowledGPT: Enhancing Large Language Models with Retrieval and Storage Access on Knowledge Bases ⭐⭐⭐⭐ 复旦肖仰华团队工作 论文速读 KnowledGPT 提出了一个通过检索知识库来增强大模型生成的 RAG 框架。 在知识库中&#xff0c;存储着三类形式的知…

数据库之数据库恢复技术思维导图+大纲笔记

大纲笔记&#xff1a; 事务的基本概念 事务 定义 用户定义的一个数据库操作系列&#xff0c;这些操作要么全做&#xff0c;要么全不做&#xff0c;是一个不可分割的基本单位 语句 BEGIN TRANSACTION 开始 COMMIT 提交&#xff0c;提交事务的所有操作 ROLLBACK 回滚&#xff0c…

BM25检索算法 python

1.简介 BM25&#xff08;Best Matching 25&#xff09;是一种经典的信息检索算法&#xff0c;是基于 TF-IDF算法的改进版本&#xff0c;旨在解决、TF-IDF算法的一些不足之处。其被广泛应用于信息检索领域的排名函数&#xff0c;用于估计文档D与用户查询Q之间的相关性。它是一种…

【AngularJs】前端使用iframe预览pdf文件报错

<iframe style"width: 100%; height: 100%;" src"{{vm.previewUrl}}"></iframe> 出现报错信息&#xff1a;Cant interpolate: {{vm.previewUrl}} 在ctrl文件中信任该文件就可以了 vm.trustUrl $sce.trustAsResourceUrl(vm.previewUrl);//信任…

CSS基础——1.CSS样式

CSS 是“Cascading Style Sheet”的缩写,中文意思为“层叠样式表”,用于描述网页的表现形式(例如网页元素的位置、大小、颜色等。css的主要作用是定义网页的样式 CSS样式 1. 行内样式 行内样式:直接定义在 HTML 标签的 style 属性中 <!DOCTYPE html> <html la…

文件读取和写入

1、with open 和 open close 的对比 with open 的优点 1、自动关闭文件&#xff1a;with 语句会在代码块执行完毕后自动关闭文件&#xff0c;无需显式调用 close() 方法。 2、异常安全&#xff1a;如果在代码块中发生异常&#xff0c;with 语句仍然会确保文件被正确关闭。 3、…

编译器的学习

常用的编译器&#xff1a; GCCVisual CClang&#xff08;LLVM&#xff09;&#xff1a; Clang 可以被看作是建立在 LLVM 之上的一个项目, 实际上LLVM是clang的后端&#xff0c;clang作为前端前端生成LLVM IR&#xff0c;https://zhuanlan.zhihu.com/p/656699711MSVC &#xff…

轻量和ECS对比:阿里云轻量应用服务器和云服务器有啥区别?

阿里云轻量应用服务器和云服务器ECS区别对照表&#xff0c;一看就懂的适用人群、使用场景、优缺点、使用限制、计费方式、网路和镜像系统全方位对比&#xff0c;阿里云服务器网aliyunfuwuqi.com整理ECS和轻量应用服务器区别对照表&#xff0c;可以在阿里云CLUB中心领取 aliyun.…

【银角大王——Django课程——ORM】

Django课程——ORM框架 Django 模型使用自带的 ORMORM 解析过程:ORM 对应关系表&#xff1a;下载mysqlclient安装包创建数据库——ORM只能操作表&#xff0c;无法创建数据库。连接数据库——修改settings中的DATABASESDjango操作表&#xff0c;在models.py文件中编写——操作表…

CPP语法(六)——函数模板

CPP语法 六—函数模板 一、 模板1.1 函数模板1.2 重载函数模板1.3 类模板1.3.1 简单类模板1.3.2 默认模板参数1.3.3 为具体类型的参数提供默认值1.3.4 有界数组模板 1.4 模板的使用1.4.1 定制模板类1.4.2 定制类模板成员函数 一、 模板 模板是c的高级特性&#xff0c;分为函数…

Prometheus 简介

Prometheus Doc 结构良好、条理清晰&#xff0c;这篇博客相当于概览&#xff0c;希望深入时建议扩展阅读官方文档。博客写作时 Prometheus 的版本为 2.51.0 。 简介 Prometheus 是 SoundCloud 于 2012 年开源的监控和告警工具&#xff0c;以独立开源项目的形式运行&#xff0…

Kafka 可视化管理工具 CMAK 启动错误 -- 命令行太长 问题解决

一、安装环境描述&#xff1a; Kafka版本&#xff1a;kafka_2.13-2.8.1cmak 版本&#xff1a;cmak-3.0.0.6安装环境&#xff1a;windows 11 二、问题描述 当我们在 命令行启动 cmak.bat 命令时&#xff0c;会报如下错误&#xff1a; 命令行太长三、解决办法 修改 cmak.bat…

Esp32-S3 进行JSON解析

之前介绍了esp32-s3的http通信,对于返回的结果进行解析也是必须的,通常我们可以使用json格式进行通信,这样即便于理解也便于取值。今天我们介绍下JSON解析。 在这里用到的库是ujson,代码如下,将如下代码保存到设备即可 import micropython import json from json import …

计算机网络相关知识总结

一、概述 计算机网络可以极大扩展计算机系统的功能机器应用范围&#xff0c;提高可靠性&#xff0c;在为用户提供放方便的同时&#xff0c;减少了整体系统费用&#xff0c;提高性价比。 计算机网络的功能主要有&#xff1a;1. 数据共享&#xff1b;2. 资源共享&#xff1b;3. 管…

Acrobat Pro DC 2021:强大的PDF编辑软件

Acrobat Pro DC 2021是Adobe公司推出的一款全面而强大的PDF编辑软件&#xff0c;凭借其卓越的性能和丰富的功能&#xff0c;成为了PDF编辑领域的领军者。 Acrobat Pro DC 2021中文激活版下载 这款软件具备全面的PDF编辑功能&#xff0c;包括文本编辑、图片处理、页面组织等&…

Golang基础3-函数、nil相关

函数 需要声明原型支持不定参数 func sum(numbers ...int)int支持返回多值支持递归支持命名返回参数 // 命名返回参数 func add(a, b int) (sum int) {sum a breturn // 这里不需要显式地写出返回值&#xff0c;因为已经在函数签名中声明了命名返回参数 } 支持匿名函数、闭包…

前端实现将二进制文件流,并下载为excel文件

目录 一、关于二进制流二、项目实践三、常见问题及解决 一、关于二进制流 含义&#xff1a;二进制流是一种计算机文件格式&#xff0c;它的数据以二进制形式存储&#xff0c;与文本文件不同。 二进制文件可以包含任意类型的数据&#xff0c;例如&#xff1a;图像、音频、视频…

go实现异常捕捉

相信大家在使用go语言开发的&#xff0c;遇到很多不熟悉或者是很多难得点吧&#xff0c;其中针对go语言的异常捕获&#xff0c;和其他的语言不一样&#xff0c;使用起来相信大家也不知道怎么使用&#xff0c;接下来会写一个小例子&#xff0c;希望大家从小例子中掌握异常捕获 …