青草久久影院-青草久久伊人-青草久久久-青草久久精品亚洲综合专区-SM双性精跪趴灌憋尿调教H-SM脚奴调教丨踩踏贱奴

17站長網

17站長網 首頁 網站 服務器 查看內容

詳解Linux lsof命令使用

2022-10-17 12:59| 查看: 1288 |來源: 互聯網

lsof(list open files)是一個查看進程打開的文件的工具。 在 linux 系統中,一切皆文件。通過文件不僅僅可以訪問常規數據,還可以訪問網絡連接和硬件。所以 lso ...

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 進程打開的文件,并截取其中的一部分結果來介紹輸出內容中都包含哪些信息:

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

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

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

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

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

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

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

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

$ sudo lsof /bin/bash

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

$ sudo lsof /dev/sda1

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

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

$ sudo lsof +d /var/log

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

$ sudo lsof +D /var/log

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

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

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

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

$ sudo lsof -p 1152

組合多個選項

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

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

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

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

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

$ sudo lsof -c cr

還可以同時指定多個 -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

只列出 IPv4 或 IPv6 打開的文件

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

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

$ sudo lsof -i:22

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

$ sudo -i TCP:1-1024

查看被打開的 UNIX domain socket 文件

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

$ sudo lsof -a -c sshd -U

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

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

$ sudo lsof -u syslog

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

$ sudo lsof -a -i -u nick

排除某個用戶

$ sudo lsof -i -u ^nick

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

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

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

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

統計系統打開的文件總數

$ sudo lsof -P -n | wc -l

命令中的 -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

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

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

上圖說明文件 /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 命令的幫助信息:

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

總結

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

以上詳解Linux lsof命令使用就是小編為大家收集整理的全部內容了,希望對大家有所幫助。如果您喜歡這篇文章,可以收藏或分享給您的小伙伴們吧!歡迎持續關注我們的后續更新。

本文最后更新于 2022-10-17 12:59,某些文章具有時效性,若有錯誤或已失效,請在網站留言或聯系站長:[email protected]
·END·
站長網微信號:w17tui,關注站長、創業、關注互聯網人 - 互聯網創業者營銷服務中心

免責聲明:本站部分文章和圖片均來自用戶投稿和網絡收集,旨在傳播知識,文章和圖片版權歸原作者及原出處所有,僅供學習與參考,請勿用于商業用途,如果損害了您的權利,請聯系我們及時修正或刪除。謝謝!

17站長網微信二維碼

始終以前瞻性的眼光聚焦站長、創業、互聯網等領域,為您提供最新最全的互聯網資訊,幫助站長轉型升級,為互聯網創業者提供更加優質的創業信息和品牌營銷服務,與站長一起進步!讓互聯網創業者不再孤獨!

掃一掃,關注站長網微信

大家都在看

  • 當我們在共享網絡訪問的時候,可能會遇到提示指定的網絡名不再可用的問題,這可能是由于我們的共享網絡出現了錯誤,也可能是被共享的對象所拒絕了。指定的網絡名 ......

    故障排除 2023-03-10
  •   文/曹楊  原標題:誰還看電視?  爸爸戴一副老花鏡,媽媽戴一副近視鏡,一人坐在沙發,一人躺在床上,各自刷著自己關注的博主更新的短視頻。電視也許開著,但只是背景。  這樣的畫面,幾乎成了洛奇家的常 ...

    站長 2020-12-09
  • 1、首先進入到“百度”軟件中, 2、然后在其中輸入“百度識圖”, 3、之后點擊圖中的“開始使用”按鈕, 4、緊接著點擊右下角的“相冊”功能, 5、在相冊下 ......

    軟件教程 2023-02-17
  • 圖片來源于簡書  文/郭開森 楊帆  陸玖財經準備開新欄目了,每周一創始人郭開森和楊帆合體郭德帆,對行業進行一些觀察和評論,第一篇我們仍是打算寫社區團購,這是當下最火的話題。  來過陸玖財經做客的朋友們...

    熱議 2020-12-07
  • 一、軟件沖突1、首先確認是否是應用程序沖突導致的。2、查看是否只有特定幾個游戲或應用會導致該問題。3、如果是應用沖突,那么只要卸載這些app就可以解決了。二 ......

    軟件教程 2022-12-27
  • 電腦端:1、大家可以點擊右邊鏈接進入網頁版的百度網盤,進入之后點擊“去登錄”。https://pan.baidu.com/2、之后正確的輸入賬號密碼進行登錄就好啦。手機端:1 ......

    軟件教程 2022-12-27
  • 一、N100對比intel i3 1、N100的跑分達到了147210分,這個數據可以達到i3的七代級別。 2、在跑分上也是超越了大部分的I3七代CPU,不過比I3八代要弱勢一些。 3 ......

    硬件知識 2023-04-26
  • 8月15日消息 上周,有媒體報道前身為百度圖片的“榴蓮”APP含有大量不雅視頻內容被用戶舉報。對此,百度圖片官方進行了回應,百度圖片表示已經對報道中所涉及的“生吃旋風哥”等爭議內容進行了下線處理。 此外,百度...

    站長 2016-08-15
  • 在填寫一些項目申請書中,總是免不了要選擇一些數字,但是在方框中如何插入數字,該怎么辦呢?那么下面就由學習啦小編給大家分享下word在方框里輸入數字的技巧, ......

    Word教程 2023-04-27
  • WPS Office手機版怎么加橫線?很多用戶還不知道WPS Office手機版怎么加橫線,WPS Office手機版怎么加橫線,WPS Office手機版怎么打橫線,WPS Office手機版怎么弄 ......

    WPS教程 2023-03-31
  • 迅雷前綴是什么 答:迅雷前綴是(magnet:?xt=urn:btih:)括號里的就是了。 我們只要在這段文字之后輸入后續的內容,就可以創建下載鏈接了。 1、磁力鏈接不基于文 ......

    軟件教程 2023-06-03
  • 一、內容特權。 1、半價點播。 許多站內視頻都需要付費觀看,而大會員用戶可以直接半價享受; 購買成功后的48h內無限次觀看。有部分的內容是只限在中國大陸內觀 ......

    軟件教程 2023-05-05
  • 1、首先打開小米運動的“實驗室功能”。 2、接著點擊“門卡模擬”。 3、然后點擊“我知道了”。 4、最后貼近就可以刷卡成功了。...

    硬件知識 2023-05-17
  • 1、打開手機輕顏相機app,點擊“我的”,點擊“設置”,2、點擊“幫助與反饋”,3、點擊右下角“在線咨詢”即可聯系客服,詢問自己的問題啦!...

    軟件教程 2023-03-16
  • 答:華為P系列: 華為p40,華為p40plus,華為p50,華為p50e,華為p60 華為mate系列: 華為mate40,華為mate50,華為mate50e,華為mate60 華為nova系列: 華為n ......

    鴻蒙系統 2023-04-24
  • 近期有用戶反映,電腦在更新Windows 11 Insider Preview 25252.1000后,出現了應用和已壓縮的文件點擊毫無反應,拖拽都不行,只能從開始菜單打開的情況,這是怎 ......

    windows11 2022-12-13
  • 可見單元格就是不包括隱藏或者篩選篩選后隱藏起來的單元格區域。方法:篩選或隱藏數據,復制需要粘貼的值,在目標單元格區域左上角的第一個單元格處右擊,選擇【 ......

    WPS教程 2022-12-10
  • 答:驍龍8+更好。 驍龍7+gen2實際上就是驍龍8+的低配版本。 在一些其他的核心架構方面都是保持一致的,比如說CPU的架構、GPU的架構等等。 驍龍7+和驍龍8+具體 ......

    硬件知識 2023-04-06
  •   文/黎明  一場針對中國互聯網巨頭的反壟斷風暴正在醞釀,而且這次動真格了。  11月10日,國家市場監管總局發布《關于平臺經濟領域的反壟斷指南(征求意見稿)》,要加大對互聯網巨頭涉嫌壟斷的調查和監管。 ...

    熱議 2020-11-14
  • win11系統如何釋放掉系統默認保留的存儲空間?一般情況下,Windows會保留一些存儲空間,以便設備獲得良好性能和成功更新。但是當出現系統盤儲存空間不足時,我們會將幾個G的保留空間釋放出來,以解燃眉之急。本期教...

    windows11 2022-11-17
  • 文件被win10系統誤報病毒自動刪除了如何進行恢復?有用戶下載了某些破解軟件卻被Win10系統誤認為是病毒文件而自動刪除,當然系統自帶殺毒軟件其實挺不錯的,就是有時候會誤報,大家遇到這種情況的時候就希望把誤刪的...

    windows10 2022-11-20
  • 1、先打開機頂盒進入主界面,并且使用遙控器打開設置。 2、然后選擇“賬號與安全”,并且進入。 3、最后往下面翻就可以看到“ADB調試”的選項,直接開啟就行了 ......

    軟件教程 2023-06-01
  • 羅技g304dpi燈顏色代表什么:1、藍色:這種情況是正常工作的顯示,如果說是常亮或者閃爍,那都沒有問題這是在正常工作呢。2、紅色:如果說是紅燈閃爍的話那就是 ......

    硬件知識 2023-03-16
  • 答:在3DMark壓力測試當中,顯卡需要超高97%才能夠算合格,證明顯卡的穩定性是過關的。 1、一般的默認情況下在2500~3000分就算很正常的了。 2、分數越高說明顯卡 ......

    軟件教程 2023-06-01
  • win11系統快速跳過聯網創建本地管理賬戶3種方法?現在市面上銷售的品牌筆記本和臺式機基本上都預裝Windows11家庭中文版正版操作系統,聯網后系統會自動激活。當用戶拿到新機器后還需要按照cortana(小娜)的提示一步...

    windows11 2022-11-13
  • 我們經常用WPS的時候,如果需要輸入波浪號~,會發現鍵盤上的波浪號輸入之后在最上面,但是為了美觀,我們希望波浪號顯示在中間。這里總結了三個方法分享給大家 ......

    WPS教程 2023-02-18
  • 答:中高端水平 i513500hx在處理器當中是處于一個中高端的水平。 i513500hx是第十一代酷睿處理器系列的一員,基礎頻率為2.4GHz,表現十分的不錯。 i513500hx介 ......

    硬件知識 2023-04-27
  • 相信有非常多使用過筆記本的用戶都聽說過獨顯直連這個詞,但很多用戶并不了解獨顯直連是什么,又有什么用處,那么下面就和小編一起來看看什么是獨顯直連和開啟這 ......

    其它 2022-12-15
  • win11系統開機總是自動登錄OneDrive如何關閉?win11系統開機的時候,會自動啟動OneDrive,不想要啟動,該怎么操作呢?下面我們就來看看詳細的教程。 在OneDrive界面點小齒輪按鈕,下拉菜單中點【設置】。 單擊【...

    windows11 2022-11-15
  • 打開軟件,直接填寫就可以。 1、下載安裝easyconnect軟件, 2、打開easyconnect應用,在如圖所示的“服務器地址”一欄輸入如圖所示網址,點擊“連接”, 3、等 ......

    軟件教程 2023-04-03

熱門排行

    最近更新

      返回頂部
      主站蜘蛛池模板: 在线中文字幕 | 不戴套挺进人妻怀孕 | 69国产精品人妻无码免费 | yin荡体育课羞耻play双性 | 亚洲日本乱码中文论理在线电影 | 浴室里强摁做开腿呻吟的漫画 | 专干老肥熟女视频网站300部 | 狠狠躁日日躁人人爽 | 爽a中文字幕一区 | 永久精品视频无码一区 | 国产精品永久免费视频观看 | 色一欲一性一乱一区二区三区 | 欧美白人极品性喷潮 | 小草视频免费观看在线 | seyeye免费高清观看 | 理论片午午伦夜理片影院 | 久久亚洲午夜牛牛影视 | 台湾18成人影院 | 亚洲中文无码AV在线观看 | 快播免费电影 | 色欲AV久久综合人妻蜜桃 | 久久国产精品永久免费网站 | 99视频精品全部免费 在线 | 嘿嘿视频在线观看 成人 | 欧美性猛交XXXX乱大交极品 | 色狠狠婷婷97 | 青青草原成人 | 亚洲一卡二卡三卡四卡无卡麻豆 | 欧美一区二区激情视频 | 国产精人妻无码一区麻豆 | 父皇轻点插好疼H限 | 中文字幕按摩 | 久久免费看少妇高潮A片特爽 | 四虎4hu亚洲精品 | 国产成人高清亚洲一区app | 在线涩涩免费观看国产精品 | 在线观看中文 | 奇米狠狠干 | 免费看午夜高清性色生活片 | 男男女女爽爽爽视频免费 | 色戒2小时38分在线观看 |