色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Linux lsof命令的基本用法

馬哥Linux運維 ? 來源:博客園sparkdev ? 2024-10-23 11:52 ? 次閱讀

lsof(list open files)是一個查看進程打開的文件的工具。

linux 系統中,一切皆文件。通過文件不僅僅可以訪問常規數據,還可以訪問網絡連接和硬件。所以 lsof 命令不僅可以查看進程打開的文件、目錄,還可以查看進程監聽的端口等 socket 相關的信息。本文將介紹 lsof 命令的基本用法,本文中 demo 的演示環境為 ubuntu 18.04。

常用選項

-a指示其它選項之間為與的關系
-c<進程名> 輸出指定進程所打開的文件
-d<文件描述符> 列出占用該文件號的進程
+d<目錄> 輸出目錄及目錄下被打開的文件和目錄(不遞歸)
+D<目錄> 遞歸輸出及目錄下被打開的文件和目錄
-i<條件> 輸出符合條件與網絡相關的文件
-n不解析主機名
-p<進程號> 輸出指定 PID 的進程所打開的文件
-P不解析端口號
-t只輸出 PID
-u輸出指定用戶打開的文件
-U輸出打開的 UNIX domain socket 文件
-h顯示幫助信息
-v顯示版本信息

基本輸出

如果不帶任何選項執行 lsof 命令,會輸出系統中所有 active 進程打開的所有文件,結果就是我們被輸出的信息所淹沒,這沒有任何的意義。我們先讓 lsof 命令輸出當前 Bash 進程打開的文件,并截取其中的一部分結果來介紹輸出內容中都包含哪些信息:

991c1536-907d-11ef-a511-92fbcf53809c.png

COMMAND:程序的名稱
PID:進程標識符
USER:進程所有者
FD:文件描述符,應用程序通過文件描述符識別該文件
TYPE:文件類型,如 DIR、REG 等
DEVICE:以逗號分隔設備編號
SIZE:文件的大小(bytes)
NODE索引節點(文件在磁盤上的標識)
NAME:打開文件的確切名稱

下面簡單介紹一下 FD 列和 TYPE 列中的常見內容。
FD 列中的常見內容有 cwd、rtd、txt、mem 和一些數字等等。其中 cwd 表示當前的工作目錄;rtd 表示根目錄;txt 表示程序的可執行文件;mem 表示內存映射文件:

994450dc-907d-11ef-a511-92fbcf53809c.png

還有一部分 FD 是以數字表示的,比如標準輸入輸出文件:

99589d1c-907d-11ef-a511-92fbcf53809c.png

數字后面的字母表示進程對該文件的讀寫模式,比如上圖中的 u 表示該文件被打開并處于讀取/寫入模式。除了 u,還有 r 表示只讀模式,w 表示只寫模式,還可以同時應用 W 表示該進程擁有對文件寫操作的鎖。下圖是截取的 docker daemon 進程打開的文件列表,其中顯示了 FD 的不同模式:

996d6292-907d-11ef-a511-92fbcf53809c.png

TYPE 列中常見的 REG 和 DIR 分別表示普通文件和目錄。而 CHR 和 BLK 則分別表示字符和塊設備,unix、fifo 和 IPv4/IPv6 分別表示 UNIX domain 套接字、先進先出(FIFO)隊列和 IPv4/IPv6 套接字。

下面我們來介紹一些 lsof 命令的常見用法。

查看哪些進程打開了某個文件

直接指定文件的名稱作為 lsof 的參加就可以查看哪些進程打開了這個文件,下面的命令查詢打開了 /bin/bash 文件的進程:

$ sudo lsof /bin/bash

9990458c-907d-11ef-a511-92fbcf53809c.png

除了普通文件,也可以是設備等文件(下面命令的輸出很長,圖示只是截取的一小部分):

$ sudo lsof /dev/sda1

99aa9b30-907d-11ef-a511-92fbcf53809c.png

查看哪些進程打開了某個目錄及目錄下的文件

這里分兩種情況,+d 選項不執行遞歸查詢,只查找那些打開了指定目錄以及指定目錄下文件和目錄的進程,比如:

$ sudo lsof +d /var/log

99d26ffc-907d-11ef-a511-92fbcf53809c.png

+D 選項則會對指定的目錄進行遞歸

$ sudo lsof +D /var/log

99ea48b6-907d-11ef-a511-92fbcf53809c.png

在卸載文件系統時,如果有進程打開了該文件系統中的文件或目錄,卸載操作就會失敗。因此最好在卸載文件系統前通過 lsof +D 檢查文件系統的掛載點,殺掉相關的進程然后再執行卸載操作。

查看某個進程打開的所有文件

通過 -p 選項并指定進程的 PID 可以輸出該進程打開的所有文件。比如我們想要查看 cron 程序打開的文件,可以先用 ps -C cron 命令查出進程的 PID:

9a0c5ce4-907d-11ef-a511-92fbcf53809c.png

然后把該 PID 傳遞給 lsof 命令的 -p 選項:

$ sudo lsof -p 1152

9a2c9b44-907d-11ef-a511-92fbcf53809c.png

組合多個選項

如果為 lsof 命令指定多個選項,這些選項間默認是或的關系。也就是說滿足任何一個選項的結果都會被輸出??梢蕴砑宇~外的 -a 選項,它的作用就是讓其它選項之間的關系變為與,比如下面的命令:

$ sudo lsof -a -p $$ -d0,1,2

9a6448fa-907d-11ef-a511-92fbcf53809c.png

其中的 -p 選項指定了當前進程的 PID,而 -d 選項則用來指定進程打開的文件描述符(可以通過逗號分隔多個文件描述符)。添加 -a 選項后,結果輸出為當前進程打開的文件描述符為 0、1、2 的文件。
說明,-a 選項的使用有很多條件,具體請參考 lsof man page。

查看指定名稱的程序打開的文件

通過 -c 選項可以匹配進程運行的程序(可執行文件)名稱。比如我們要查找以字母 cr 開頭的程序打開的文件列表:

$ sudo lsof -c cr

9a7ef934-907d-11ef-a511-92fbcf53809c.png

還可以同時指定多個 -c 選項,它們之間是或的關系。
如果想對 -c 選項的條件取反,只要在字符串前添加符號 ^ 就可以了,比如:

$ sudo lsof -c ^cr

-c 選項也支持正則表達式,比如下面的命令可以過濾出以 cra 和 cro 開頭的程序打開的文件:

$ sudo lsof -c /cr[ao]/

查看被打開的與網絡相關的文件

-i 選項用來查看被打開的和網絡相關的文件,其參數的格式如下:
[46][protocol][@hostname|hostaddr][:service|port]
46表示 IP 協議的版本
protocol表示網絡協議的名稱,比如 TCP 或 UDP
hostname或 hostaddr 表示主機地址
service指 /etc/services 中的名稱,比如 smtp 或多個服務的列表
port表示端口號,可以指定一個或多個

-i 選項默認會同時輸出 IPv4 和 IPv6 打開的文件:

$ sudo lsof -i

9a97c892-907d-11ef-a511-92fbcf53809c.png

只列出 IPv4 或 IPv6 打開的文件

$ sudo lsof -i 4
$ sudo lsof -i 6

9aaee7d4-907d-11ef-a511-92fbcf53809c.png

列出與 22 號端口相關的文件

$ sudo lsof -i:22

9ac1e99c-907d-11ef-a511-92fbcf53809c.png

列出指定范圍內被打開的 TCP 端口

$ sudo -i TCP:1-1024

9ad116e2-907d-11ef-a511-92fbcf53809c.png

查看被打開的 UNIX domain socket 文件

-U 選項輸出打開的 UNIX domain socket 文件,這里我們結合 -c 選項來查看 ssh 服務打開的 UNIX domain socket 文件:

$ sudo lsof -a -c sshd -U

9af5085e-907d-11ef-a511-92fbcf53809c.png

查看某個用戶打開的所有文件

-u 選項可以指定用戶名或 user ID,并且和 -c 選項一樣,可以通過逗號分隔多個用戶名稱或 user ID,也可以通過符號 ^ 對條件取反。
查看某個用戶打開的所有文件

$ sudo lsof -u syslog

9b15baf4-907d-11ef-a511-92fbcf53809c.png

查看用戶 nick 打開的網絡相關的文件

$ sudo lsof -a -i -u nick

9b3565de-907d-11ef-a511-92fbcf53809c.png

排除某個用戶

$ sudo lsof -i -u ^nick

9b54233e-907d-11ef-a511-92fbcf53809c.png

注意:在有排除條件時,不需要指定 -a 選項。

殺掉某個用戶打開了文件的所有進程

$ kill -9 $(lsof -t -u nick)

該命令中的 -t 選項讓 lsof 命令只輸出進程的 PID:

9b693b02-907d-11ef-a511-92fbcf53809c.png

統計系統打開的文件總數

$ sudo lsof -P -n | wc -l

9b8b2384-907d-11ef-a511-92fbcf53809c.png

命令中的 -P 選項表示不解析端口號,-n 選項表示不解析主機名,這兩個選項主要的目的是為了提升 lsof 命令的執行速度。wc -l 命令則用來統計 lsof 命令輸出的行數。

恢復刪除的文件

如果我們一不小心刪除了文件,而又知道這個文本被某個進程打開著,就可以通過 lsof 命令來恢復該文件。具體的原理為:
當進程打開了某個文件時,只要該進程保持打開該文件,即使將文件刪除,它依然存在于磁盤中。進程并不知道文件已經被刪除,它仍然可以通過打開該文件時提供給它的文件描述符進行讀取和寫入。除了該進程之外,這個文件是不可見的,因為已經刪除了其相應的目錄索引節點。
進程打開的文件描述符就存放在 /proc/PID/fd 目錄下。/proc 目錄掛載的是在內存中所映射的一塊區域,所以這些文件和目錄并不存在于磁盤中,因此當我們對這些文件進行讀取和寫入時,實際上是在從內存中獲取相關信息。lsof 程序就是使用這些信息和其他關于內核內部狀態的信息來產生其輸出。所以 lsof 可以顯示進程的文件描述符和相關的文件名等信息。也就是說我們通過訪問進程的文件描述符可以找到該文件的相關信息。
下面的 demo 演示如何通過 lsof 命令恢復被誤刪的 /var/log/syslog 文件。
先刪除日志文件 /var/log/syslog,記著要提前備份一下這個文件,以防萬一:

$ sudo rm /var/log/syslog

9b9cb932-907d-11ef-a511-92fbcf53809c.png

從上面的信息可以看到 PID 為 1141 的進程打開著該文件,文件描述符為 7,并且顯示該文件已經被刪除了。接下來我們通過 1141 號進程的文件文件描述符來查看該文件的內容:

$ sudo tail -n 5 /proc/1141/fd/7

9bb8c230-907d-11ef-a511-92fbcf53809c.png

上圖說明文件 /var/log/syslog 文件的內容還在,并且可以通過文件描述符訪問,接下來通過 IO 重定向的方式重新創建 /var/log/syslog 文件就可以了:

$ sudo sh -c 'cat /proc/1141/fd/7 > /var/log/syslog' 

然后修復文件的權限屬性并重啟 rsyslog 服務:

$ sudo chown syslog:adm /var/log/syslog
$ sudo systemctl restart rsyslog.service

這樣就完成了 /var/log/syslog 文件的恢復工作。對于許多應用程序,尤其是日志文件和數據庫文件,都可以通過這種方式來恢復。

幫助

-h 選項會輸出 lsof 命令的幫助信息:

9be08cc0-907d-11ef-a511-92fbcf53809c.png

估計這樣的幫助信息也只能逼著你去讀 man page 了!

總結

lsof 并不是一個簡單的命令,從其 man page 的長度就可以體會到這一點。從本文介紹的小 demo 入手或許可以讓你忘記冗長的文檔說明,一步步的開始使用并最終掌握這個命令。

鏈接:https://www.cnblogs.com/sparkdev/p/10271351.html

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • Linux
    +關注

    關注

    87

    文章

    11292

    瀏覽量

    209323
  • 程序
    +關注

    關注

    117

    文章

    3785

    瀏覽量

    81003
  • 命令
    +關注

    關注

    5

    文章

    683

    瀏覽量

    22011
  • 進程
    +關注

    關注

    0

    文章

    203

    瀏覽量

    13960

原文標題:深入解析 Linux lsof 命令:網絡排查利器與文件管理神器

文章出處:【微信號:magedu-Linux,微信公眾號:馬哥Linux運維】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    Linux find命令用法

    可以很肯定地說,find 命令Linux 后臺開發人員必須熟知的操作之一,除非您使用的是 Windows Server。
    發表于 10-12 11:27 ?564次閱讀

    linux運維命令大全

    僅是對Linux高端運維實用命令的簡單匯總,不同的命令有相應用法和可實現的功能,具體使用方法,可自行查找!
    發表于 03-15 16:36

    linux中comm命令用法

    linux系統中comm命令用法詳解 linux系統下的comm命令是一個非常實用的文件對比命令
    發表于 07-04 08:22

    Linux中的35個find命令用法

    Linux查找命令Linux系統中最重要和最常用的命令之一。查找用于根據與參數匹配的文件指定的條件來搜索和查找文件和目錄列表的命令
    的頭像 發表于 02-02 16:53 ?3662次閱讀
    <b class='flag-5'>Linux</b>中的35個find<b class='flag-5'>命令</b><b class='flag-5'>用法</b>

    使用Linux命令lsof查看進程打開和查看文件的說明

    linux命令lsof 查看進程打開那些文件 或者 查看文件給那個進程使用對調試文件有很好的幫助和精準定位問題
    發表于 10-28 08:00 ?0次下載

    詳談Linux的find命令

    find 是 Linux 下最有用的命令之一,熟練的使用它對于提高工作效率很有幫助。下面介紹它的一些用法
    的頭像 發表于 06-23 09:43 ?3092次閱讀
    詳談<b class='flag-5'>Linux</b>的find<b class='flag-5'>命令</b>

    linux的scp命令怎么用_linux的grep命令用法

    linux中,scp命令用于Linux之間復制文件和目錄,即在一臺Linux服務器中將本地的文件上傳到一臺遠端服務器,或將遠端服務器的文件下載到本地。scp是
    發表于 09-04 15:36 ?4422次閱讀
    <b class='flag-5'>linux</b>的scp<b class='flag-5'>命令</b>怎么用_<b class='flag-5'>linux</b>的grep<b class='flag-5'>命令</b><b class='flag-5'>用法</b>

    如何在Linux使用touch命令

    Linux touch命令用于更改文件時間戳。但touch命令的最常見用法是創建文件。
    的頭像 發表于 12-05 17:21 ?2071次閱讀

    Linux系統維護命令用法

    Linux有很多命令,每個命令基本可以用一篇文章介紹,本文僅簡單總結一些常用系統維護命令用法
    的頭像 發表于 04-17 14:57 ?1042次閱讀
    <b class='flag-5'>Linux</b>系統維護<b class='flag-5'>命令</b>的<b class='flag-5'>用法</b>

    linux中source命令用法

    Linux中,source命令通常用于重新執行剛修改的初始化文件,使之立即生效,而不必注銷并重新登錄。source命令可以用于讀取并執行腳本文件中的命令,通常用于在當前shell環境
    的頭像 發表于 11-08 14:35 ?2326次閱讀

    linux查看物理接口的命令

    Linux操作系統提供了多種命令和工具來查看物理接口。在這篇文章中,我們將詳細介紹一些最常用和常見的命令,以及它們的用法和輸出。 ifconfig
    的頭像 發表于 11-16 16:48 ?1262次閱讀

    linux常用命令用法

    Linux是一種開源的操作系統,它以穩定、高效和安全的特點受到廣大用戶的喜愛。掌握Linux的常用命令及其用法對于操作系統的管理和開發都至關重要。本文將詳盡、詳實、細致地介紹
    的頭像 發表于 11-17 09:47 ?656次閱讀

    總結linux命令行的主要用法

    Linux命令行是一種在Linux操作系統中通過文本界面來執行指令和管理系統的方式。它提供了豐富的功能和靈活性,幫助用戶完成各種任務。本文將詳細介紹Linux
    的頭像 發表于 11-17 10:19 ?662次閱讀

    使用lsof實現對linux文件的誤刪除恢復練習

    本文記錄使用lsof實現對linux文件的誤刪除恢復練習。題目如下: 1.確保當前nginx進程運行中 2.刪除日志文件,rm -f /var/log/nginx/access.log 3.以
    的頭像 發表于 11-24 11:14 ?174次閱讀
    使用<b class='flag-5'>lsof</b>實現對<b class='flag-5'>linux</b>文件的誤刪除恢復練習

    盤點Linux系統中的常見命令

    作為運維同學怎能不知道Linux系統中的lsmod、lsof、lspci、lsscsi命令呢,今天就來盤一盤她及實例。
    的頭像 發表于 12-03 09:48 ?220次閱讀
    盤點<b class='flag-5'>Linux</b>系統中的常見<b class='flag-5'>命令</b>
    主站蜘蛛池模板: 国产成a人片在线观看视频99| 野草在线视频完整视频| 泰国淫乐园实录| CHINESE熟女老女人HD视频| 久久99r66热这里只有精品| 亚洲AV无码一区二区色情蜜芽 | 日本xxxxx按摩19| 2020美女视频黄频大全视频| 久久全国免费久久青青小草| 伊人在线视频| 九九热视频免费观看| 亚洲午夜精品A片久久WWW解说| 国产综合欧美区在线| 亚洲精品成人无码A片在线| 海角国精产品一区一区三区糖心| 亚洲av欧美在我| 国内精品伊人久久久影院| 亚洲成人综合在线| 久久成人伊人欧洲精品AV| 印度最猛性ⅹxxxxx| 老司机深夜福利ae 入口网站 | 亚洲精品乱码一区二区三区 | 蜜桃久久久亚洲精品成人| 91次元黄色观看| 青青伊人久久| 国产精品99AV在线观看| 亚洲国产AV精品一区二区蜜芽| 精品国产mmd在线观看| 在线A亚洲老鸭窝天堂AV高清| 麻花豆传媒剧国产免费mv观看| av在线观看网站免费| 色悠久久综合| 国偷自产视频一区二区久| 怡春院欧美一区二区三区免费| 老司机亚洲精品影院在线观看| a级成人免费毛片完整版| 日韩在线视频www色| 韩国演艺圈悲惨在线| 姉调无修版ova国语版| 青柠在线观看免费完整版| 国产精品久久久久精品A片软件|