lsof(list open files)是一個(gè)查看進(jìn)程打開的文件的工具。 在 linux 系統(tǒng)中,一切皆文件。通過文件不僅僅可以訪問常規(guī)數(shù)據(jù),還可以訪問網(wǎng)絡(luò)連接和硬件。所以 lsof 命令不僅可以查看進(jìn)程打開的文件、目錄,還可以查看進(jìn)程監(jiān)聽的端口等 socket 相關(guān)的信息。本文將介紹 lsof 命令的基本用法,本文中 demo 的演示環(huán)境為 ubuntu 18.04。 常用選項(xiàng) -a 指示其它選項(xiàng)之間為與的關(guān)系 基本輸出 如果不帶任何選項(xiàng)執(zhí)行 lsof 命令,會(huì)輸出系統(tǒng)中所有 active 進(jìn)程打開的所有文件,結(jié)果就是我們被輸出的信息所淹沒,這沒有任何的意義。我們先讓 lsof 命令輸出當(dāng)前 Bash 進(jìn)程打開的文件,并截取其中的一部分結(jié)果來介紹輸出內(nèi)容中都包含哪些信息: COMMAND:程序的名稱 下面簡單介紹一下 FD 列和 TYPE 列中的常見內(nèi)容。 還有一部分 FD 是以數(shù)字表示的,比如標(biāo)準(zhǔn)輸入輸出文件: 數(shù)字后面的字母表示進(jìn)程對該文件的讀寫模式,比如上圖中的 u 表示該文件被打開并處于讀取/寫入模式。除了 u,還有 r 表示只讀模式,w 表示只寫模式,還可以同時(shí)應(yīng)用 W 表示該進(jìn)程擁有對文件寫操作的鎖。下圖是截取的 docker daemon 進(jìn)程打開的文件列表,其中顯示了 FD 的不同模式: TYPE 列中常見的 REG 和 DIR 分別表示普通文件和目錄。而 CHR 和 BLK 則分別表示字符和塊設(shè)備,unix、fifo 和 IPv4/IPv6 分別表示 UNIX domain 套接字、先進(jìn)先出(FIFO)隊(duì)列和 IPv4/IPv6 套接字。 下面我們來介紹一些 lsof 命令的常見用法。 查看哪些進(jìn)程打開了某個(gè)文件 直接指定文件的名稱作為 lsof 的參加就可以查看哪些進(jìn)程打開了這個(gè)文件,下面的命令查詢打開了 /bin/bash 文件的進(jìn)程: $ sudo lsof /bin/bash 除了普通文件,也可以是設(shè)備等文件(下面命令的輸出很長,圖示只是截取的一小部分): $ sudo lsof /dev/sda1 查看哪些進(jìn)程打開了某個(gè)目錄及目錄下的文件 這里分兩種情況,+d 選項(xiàng)不執(zhí)行遞歸查詢,只查找那些打開了指定目錄以及指定目錄下文件和目錄的進(jìn)程,比如: $ sudo lsof +d /var/log 而 +D 選項(xiàng)則會(huì)對指定的目錄進(jìn)行遞歸: $ sudo lsof +D /var/log 在卸載文件系統(tǒng)時(shí),如果有進(jìn)程打開了該文件系統(tǒng)中的文件或目錄,卸載操作就會(huì)失敗。因此最好在卸載文件系統(tǒng)前通過 lsof +D 檢查文件系統(tǒng)的掛載點(diǎn),殺掉相關(guān)的進(jìn)程然后再執(zhí)行卸載操作。 查看某個(gè)進(jìn)程打開的所有文件 通過 -p 選項(xiàng)并指定進(jìn)程的 PID 可以輸出該進(jìn)程打開的所有文件。比如我們想要查看 cron 程序打開的文件,可以先用 ps -C cron 命令查出進(jìn)程的 PID: 然后把該 PID 傳遞給 lsof 命令的 -p 選項(xiàng): $ sudo lsof -p 1152 組合多個(gè)選項(xiàng) 如果為 lsof 命令指定多個(gè)選項(xiàng),這些選項(xiàng)間默認(rèn)是或的關(guān)系。也就是說滿足任何一個(gè)選項(xiàng)的結(jié)果都會(huì)被輸出。可以添加額外的 -a 選項(xiàng),它的作用就是讓其它選項(xiàng)之間的關(guān)系變?yōu)榕c,比如下面的命令: $ sudo lsof -a -p $$ -d0,1,2 其中的 -p 選項(xiàng)指定了當(dāng)前進(jìn)程的 PID,而 -d 選項(xiàng)則用來指定進(jìn)程打開的文件描述符(可以通過逗號分隔多個(gè)文件描述符)。添加 -a 選項(xiàng)后,結(jié)果輸出為當(dāng)前進(jìn)程打開的文件描述符為 0、1、2 的文件。 查看指定名稱的程序打開的文件 通過 -c 選項(xiàng)可以匹配進(jìn)程運(yùn)行的程序(可執(zhí)行文件)名稱。比如我們要查找以字母 cr 開頭的程序打開的文件列表: $ sudo lsof -c cr 還可以同時(shí)指定多個(gè) -c 選項(xiàng),它們之間是或的關(guān)系。 $ sudo lsof -c ^cr -c 選項(xiàng)也支持正則表達(dá)式,比如下面的命令可以過濾出以 cra 和 cro 開頭的程序打開的文件: $ sudo lsof -c /cr[ao]/ 查看被打開的與網(wǎng)絡(luò)相關(guān)的文件 -i 選項(xiàng)用來查看被打開的和網(wǎng)絡(luò)相關(guān)的文件,其參數(shù)的格式如下: -i 選項(xiàng)默認(rèn)會(huì)同時(shí)輸出 IPv4 和 IPv6 打開的文件: $ sudo lsof -i 只列出 IPv4 或 IPv6 打開的文件 $ sudo lsof -i 4 $ sudo lsof -i 6 列出與 22 號端口相關(guān)的文件 $ sudo lsof -i:22 列出指定范圍內(nèi)被打開的 TCP 端口 $ sudo -i TCP:1-1024 查看被打開的 UNIX domain socket 文件 -U 選項(xiàng)輸出打開的 UNIX domain socket 文件,這里我們結(jié)合 -c 選項(xiàng)來查看 ssh 服務(wù)打開的 UNIX domain socket 文件: $ sudo lsof -a -c sshd -U 查看某個(gè)用戶打開的所有文件 -u 選項(xiàng)可以指定用戶名或 user ID,并且和 -c 選項(xiàng)一樣,可以通過逗號分隔多個(gè)用戶名稱或 user ID,也可以通過符號 ^ 對條件取反。 $ sudo lsof -u syslog 查看用戶 nick 打開的網(wǎng)絡(luò)相關(guān)的文件 $ sudo lsof -a -i -u nick 排除某個(gè)用戶 $ sudo lsof -i -u ^nick 注意:在有排除條件時(shí),不需要指定 -a 選項(xiàng)。 殺掉某個(gè)用戶打開了文件的所有進(jìn)程 $ kill -9 $(lsof -t -u nick) 該命令中的 -t 選項(xiàng)讓 lsof 命令只輸出進(jìn)程的 PID: 統(tǒng)計(jì)系統(tǒng)打開的文件總數(shù) $ sudo lsof -P -n | wc -l 命令中的 -P 選項(xiàng)表示不解析端口號,-n 選項(xiàng)表示不解析主機(jī)名,這兩個(gè)選項(xiàng)主要的目的是為了提升 lsof 命令的執(zhí)行速度。wc -l 命令則用來統(tǒng)計(jì) lsof 命令輸出的行數(shù)。 恢復(fù)刪除的文件 如果我們一不小心刪除了文件,而又知道這個(gè)文本被某個(gè)進(jìn)程打開著,就可以通過 lsof 命令來恢復(fù)該文件。具體的原理為: 進(jìn)程打開的文件描述符就存放在 /proc/PID/fd 目錄下。/proc 目錄掛載的是在內(nèi)存中所映射的一塊區(qū)域,所以這些文件和目錄并不存在于磁盤中,因此當(dāng)我們對這些文件進(jìn)行讀取和寫入時(shí),實(shí)際上是在從內(nèi)存中獲取相關(guān)信息。lsof 程序就是使用這些信息和其他關(guān)于內(nèi)核內(nèi)部狀態(tài)的信息來產(chǎn)生其輸出。所以 lsof 可以顯示進(jìn)程的文件描述符和相關(guān)的文件名等信息。也就是說我們通過訪問進(jìn)程的文件描述符可以找到該文件的相關(guān)信息。 下面的 demo 演示如何通過 lsof 命令恢復(fù)被誤刪的 /var/log/syslog 文件。 先刪除日志文件 /var/log/syslog,記著要提前備份一下這個(gè)文件,以防萬一: $ sudo rm /var/log/syslog 從上面的信息可以看到 PID 為 1141 的進(jìn)程打開著該文件,文件描述符為 7,并且顯示該文件已經(jīng)被刪除了。接下來我們通過 1141 號進(jìn)程的文件文件描述符來查看該文件的內(nèi)容: $ sudo tail -n 5 /proc/1141/fd/7 上圖說明文件 /var/log/syslog 文件的內(nèi)容還在,并且可以通過文件描述符訪問,接下來通過 IO 重定向的方式重新創(chuàng)建 /var/log/syslog 文件就可以了: $ sudo sh -c 'cat /proc/1141/fd/7 > /var/log/syslog' 然后修復(fù)文件的權(quán)限屬性并重啟 rsyslog 服務(wù): $ sudo chown syslog:adm /var/log/syslog $ sudo systemctl restart rsyslog.service 這樣就完成了 /var/log/syslog 文件的恢復(fù)工作。對于許多應(yīng)用程序,尤其是日志文件和數(shù)據(jù)庫文件,都可以通過這種方式來恢復(fù)。 幫助 -h 選項(xiàng)會(huì)輸出 lsof 命令的幫助信息: 估計(jì)這樣的幫助信息也只能逼著你去讀 man page 了! 總結(jié) lsof 并不是一個(gè)簡單的命令,從其 man page 的長度就可以體會(huì)到這一點(diǎn)。從本文介紹的小 demo 入手或許可以讓你忘記冗長的文檔說明,一步步的開始使用并最終掌握這個(gè)命令。 以上詳解Linux lsof命令使用就是小編為大家收集整理的全部內(nèi)容了,希望對大家有所幫助。如果您喜歡這篇文章,可以收藏或分享給您的小伙伴們吧!歡迎持續(xù)關(guān)注我們的后續(xù)更新。 |
免責(zé)聲明:本站部分文章和圖片均來自用戶投稿和網(wǎng)絡(luò)收集,旨在傳播知識(shí),文章和圖片版權(quán)歸原作者及原出處所有,僅供學(xué)習(xí)與參考,請勿用于商業(yè)用途,如果損害了您的權(quán)利,請聯(lián)系我們及時(shí)修正或刪除。謝謝!
始終以前瞻性的眼光聚焦站長、創(chuàng)業(yè)、互聯(lián)網(wǎng)等領(lǐng)域,為您提供最新最全的互聯(lián)網(wǎng)資訊,幫助站長轉(zhuǎn)型升級,為互聯(lián)網(wǎng)創(chuàng)業(yè)者提供更加優(yōu)質(zhì)的創(chuàng)業(yè)信息和品牌營銷服務(wù),與站長一起進(jìn)步!讓互聯(lián)網(wǎng)創(chuàng)業(yè)者不再孤獨(dú)!
掃一掃,關(guān)注站長網(wǎng)微信
當(dāng)我們在共享網(wǎng)絡(luò)訪問的時(shí)候,可能會(huì)遇到提示指定的網(wǎng)絡(luò)名不再可用的問題,這可能是由于我們的共享網(wǎng)絡(luò)出現(xiàn)了錯(cuò)誤,也可能是被共享的對象所拒絕了。指定的網(wǎng)絡(luò)名 ......
文/曹楊 原標(biāo)題:誰還看電視? 爸爸戴一副老花鏡,媽媽戴一副近視鏡,一人坐在沙發(fā),一人躺在床上,各自刷著自己關(guān)注的博主更新的短視頻。電視也許開著,但只是背景。 這樣的畫面,幾乎成了洛奇家的常 ...
1、首先進(jìn)入到“百度”軟件中, 2、然后在其中輸入“百度識(shí)圖”, 3、之后點(diǎn)擊圖中的“開始使用”按鈕, 4、緊接著點(diǎn)擊右下角的“相冊”功能, 5、在相冊下 ......
圖片來源于簡書 文/郭開森 楊帆 陸玖財(cái)經(jīng)準(zhǔn)備開新欄目了,每周一創(chuàng)始人郭開森和楊帆合體郭德帆,對行業(yè)進(jìn)行一些觀察和評論,第一篇我們?nèi)允谴蛩銓懮鐓^(qū)團(tuán)購,這是當(dāng)下最火的話題。 來過陸玖財(cái)經(jīng)做客的朋友們...
一、軟件沖突1、首先確認(rèn)是否是應(yīng)用程序沖突導(dǎo)致的。2、查看是否只有特定幾個(gè)游戲或應(yīng)用會(huì)導(dǎo)致該問題。3、如果是應(yīng)用沖突,那么只要卸載這些app就可以解決了。二 ......
電腦端:1、大家可以點(diǎn)擊右邊鏈接進(jìn)入網(wǎng)頁版的百度網(wǎng)盤,進(jìn)入之后點(diǎn)擊“去登錄”。https://pan.baidu.com/2、之后正確的輸入賬號密碼進(jìn)行登錄就好啦。手機(jī)端:1 ......
一、N100對比intel i3 1、N100的跑分達(dá)到了147210分,這個(gè)數(shù)據(jù)可以達(dá)到i3的七代級別。 2、在跑分上也是超越了大部分的I3七代CPU,不過比I3八代要弱勢一些。 3 ......
在填寫一些項(xiàng)目申請書中,總是免不了要選擇一些數(shù)字,但是在方框中如何插入數(shù)字,該怎么辦呢?那么下面就由學(xué)習(xí)啦小編給大家分享下word在方框里輸入數(shù)字的技巧, ......
8月15日消息 上周,有媒體報(bào)道前身為百度圖片的“榴蓮”APP含有大量不雅視頻內(nèi)容被用戶舉報(bào)。對此,百度圖片官方進(jìn)行了回應(yīng),百度圖片表示已經(jīng)對報(bào)道中所涉及的“生吃旋風(fēng)哥”等爭議內(nèi)容進(jìn)行了下線處理。 此外,百度...
WPS Office手機(jī)版怎么加橫線?很多用戶還不知道WPS Office手機(jī)版怎么加橫線,WPS Office手機(jī)版怎么加橫線,WPS Office手機(jī)版怎么打橫線,WPS Office手機(jī)版怎么弄 ......
迅雷前綴是什么 答:迅雷前綴是(magnet:?xt=urn:btih:)括號里的就是了。 我們只要在這段文字之后輸入后續(xù)的內(nèi)容,就可以創(chuàng)建下載鏈接了。 1、磁力鏈接不基于文 ......
一、內(nèi)容特權(quán)。 1、半價(jià)點(diǎn)播。 許多站內(nèi)視頻都需要付費(fèi)觀看,而大會(huì)員用戶可以直接半價(jià)享受; 購買成功后的48h內(nèi)無限次觀看。有部分的內(nèi)容是只限在中國大陸內(nèi)觀 ......
1、首先打開小米運(yùn)動(dòng)的“實(shí)驗(yàn)室功能”。 2、接著點(diǎn)擊“門卡模擬”。 3、然后點(diǎn)擊“我知道了”。 4、最后貼近就可以刷卡成功了。...
1、打開手機(jī)輕顏相機(jī)app,點(diǎn)擊“我的”,點(diǎn)擊“設(shè)置”,2、點(diǎn)擊“幫助與反饋”,3、點(diǎn)擊右下角“在線咨詢”即可聯(lián)系客服,詢問自己的問題啦!...
答:華為P系列: 華為p40,華為p40plus,華為p50,華為p50e,華為p60 華為mate系列: 華為mate40,華為mate50,華為mate50e,華為mate60 華為nova系列: 華為n ......
近期有用戶反映,電腦在更新Windows 11 Insider Preview 25252.1000后,出現(xiàn)了應(yīng)用和已壓縮的文件點(diǎn)擊毫無反應(yīng),拖拽都不行,只能從開始菜單打開的情況,這是怎 ......
可見單元格就是不包括隱藏或者篩選篩選后隱藏起來的單元格區(qū)域。方法:篩選或隱藏?cái)?shù)據(jù),復(fù)制需要粘貼的值,在目標(biāo)單元格區(qū)域左上角的第一個(gè)單元格處右擊,選擇【 ......
答:驍龍8+更好。 驍龍7+gen2實(shí)際上就是驍龍8+的低配版本。 在一些其他的核心架構(gòu)方面都是保持一致的,比如說CPU的架構(gòu)、GPU的架構(gòu)等等。 驍龍7+和驍龍8+具體 ......
文/黎明 一場針對中國互聯(lián)網(wǎng)巨頭的反壟斷風(fēng)暴正在醞釀,而且這次動(dòng)真格了。 11月10日,國家市場監(jiān)管總局發(fā)布《關(guān)于平臺(tái)經(jīng)濟(jì)領(lǐng)域的反壟斷指南(征求意見稿)》,要加大對互聯(lián)網(wǎng)巨頭涉嫌壟斷的調(diào)查和監(jiān)管。 ...
win11系統(tǒng)如何釋放掉系統(tǒng)默認(rèn)保留的存儲(chǔ)空間?一般情況下,Windows會(huì)保留一些存儲(chǔ)空間,以便設(shè)備獲得良好性能和成功更新。但是當(dāng)出現(xiàn)系統(tǒng)盤儲(chǔ)存空間不足時(shí),我們會(huì)將幾個(gè)G的保留空間釋放出來,以解燃眉之急。本期教...
文件被win10系統(tǒng)誤報(bào)病毒自動(dòng)刪除了如何進(jìn)行恢復(fù)?有用戶下載了某些破解軟件卻被Win10系統(tǒng)誤認(rèn)為是病毒文件而自動(dòng)刪除,當(dāng)然系統(tǒng)自帶殺毒軟件其實(shí)挺不錯(cuò)的,就是有時(shí)候會(huì)誤報(bào),大家遇到這種情況的時(shí)候就希望把誤刪的...
1、先打開機(jī)頂盒進(jìn)入主界面,并且使用遙控器打開設(shè)置。 2、然后選擇“賬號與安全”,并且進(jìn)入。 3、最后往下面翻就可以看到“ADB調(diào)試”的選項(xiàng),直接開啟就行了 ......
答:在3DMark壓力測試當(dāng)中,顯卡需要超高97%才能夠算合格,證明顯卡的穩(wěn)定性是過關(guān)的。 1、一般的默認(rèn)情況下在2500~3000分就算很正常的了。 2、分?jǐn)?shù)越高說明顯卡 ......
羅技g304dpi燈顏色代表什么:1、藍(lán)色:這種情況是正常工作的顯示,如果說是常亮或者閃爍,那都沒有問題這是在正常工作呢。2、紅色:如果說是紅燈閃爍的話那就是 ......
win11系統(tǒng)快速跳過聯(lián)網(wǎng)創(chuàng)建本地管理賬戶3種方法?現(xiàn)在市面上銷售的品牌筆記本和臺(tái)式機(jī)基本上都預(yù)裝Windows11家庭中文版正版操作系統(tǒng),聯(lián)網(wǎng)后系統(tǒng)會(huì)自動(dòng)激活。當(dāng)用戶拿到新機(jī)器后還需要按照cortana(小娜)的提示一步...
答:中高端水平 i513500hx在處理器當(dāng)中是處于一個(gè)中高端的水平。 i513500hx是第十一代酷睿處理器系列的一員,基礎(chǔ)頻率為2.4GHz,表現(xiàn)十分的不錯(cuò)。 i513500hx介 ......
我們經(jīng)常用WPS的時(shí)候,如果需要輸入波浪號~,會(huì)發(fā)現(xiàn)鍵盤上的波浪號輸入之后在最上面,但是為了美觀,我們希望波浪號顯示在中間。這里總結(jié)了三個(gè)方法分享給大家 ......
相信有非常多使用過筆記本的用戶都聽說過獨(dú)顯直連這個(gè)詞,但很多用戶并不了解獨(dú)顯直連是什么,又有什么用處,那么下面就和小編一起來看看什么是獨(dú)顯直連和開啟這 ......
win11系統(tǒng)開機(jī)總是自動(dòng)登錄OneDrive如何關(guān)閉?win11系統(tǒng)開機(jī)的時(shí)候,會(huì)自動(dòng)啟動(dòng)OneDrive,不想要啟動(dòng),該怎么操作呢?下面我們就來看看詳細(xì)的教程。 在OneDrive界面點(diǎn)小齒輪按鈕,下拉菜單中點(diǎn)【設(shè)置】。 單擊【...
打開軟件,直接填寫就可以。 1、下載安裝easyconnect軟件, 2、打開easyconnect應(yīng)用,在如圖所示的“服務(wù)器地址”一欄輸入如圖所示網(wǎng)址,點(diǎn)擊“連接”, 3、等 ......