www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 技術學院 > 技術前線
[導讀]在Linux系統(tǒng)中,進程是計算機運行中最基本的單位,它負責執(zhí)行程序和管理系統(tǒng)資源。了解和查看Linux進程對于系統(tǒng)管理和故障排查都非常重要。

在Linux系統(tǒng)中,進程是計算機運行中最基本的單位,它負責執(zhí)行程序和管理系統(tǒng)資源。了解和查看Linux進程對于系統(tǒng)管理和故障排查都非常重要。為大家介紹Linux進程的查看方法和技巧,幫助大家更好地了解和管理系統(tǒng)進程。

操作系統(tǒng)「進程」是學計算機都要接觸的基本概念,拋開那些純理論的操作系統(tǒng)底層實現(xiàn),在Linux下做軟件開發(fā)這么多年,每次程序運行出現(xiàn)問題,都要一步一步分析進程各種狀態(tài),去排查問題出在哪里,這次lemon帶你在Linux環(huán)境下實操,一步步探究揭開「Linux進程」的那些秘密。

何為進程

首先我們說下「程序」的概念,程序是一些保存在磁盤上的指令的有序集合,是靜態(tài)的。進程是程序執(zhí)行的過程,包括了動態(tài)創(chuàng)建、調(diào)度和消亡的整個過程,它是程序資源管理的最小單位。

線程是操作操作系統(tǒng)能夠進行運算調(diào)度的最小單位。大部分情況下,它被包含在進程之中,是進程中的實際運作單位,一個進程內(nèi)可以包含多個線程,是資源調(diào)度的最小單位。[引用維基百科]

探究進程第一步,你在嗎?還好嗎?

ps

report a snapshot of the current processes. 列出當前系統(tǒng)進程的快照。

找到進程PID ( Process IDentity ),pid唯一標識一個進程。用ps這個命令,這個命令大家應該都知道吧,對于小白用戶,首先他不是Photoshop。

給大家簡單介紹一下,一般用法是ps -ef列出系統(tǒng)內(nèi)經(jīng)常信息,通常都會帶管道grep出自己感興趣的進程,像這樣ps -ef|grep intresting第一列PID代表進程號,PPID(parent process ID)代表父進程號。

探究進程第二步,讓我看看你都交了哪些朋友(系統(tǒng)調(diào)用 & 信號)

strace

trace system calls and signals 跟蹤進程內(nèi)部的系統(tǒng)調(diào)用和信號

什么是「系統(tǒng)調(diào)用」?系統(tǒng)調(diào)用(system call),指運行在「用戶態(tài)」的程序向操作系統(tǒng)「內(nèi)核態(tài)」請求需要更高權限運行的服務,系統(tǒng)調(diào)用提供用戶程序與操作系統(tǒng)之間的接口。

strace后面跟著啟動一個進程,可以跟蹤啟動后進程的系統(tǒng)調(diào)用和信號,這個命令可以看到進程執(zhí)行時候都調(diào)用了哪些系統(tǒng)調(diào)用,通過指定不同的選項可以輸出系統(tǒng)調(diào)用發(fā)生的時間,精度可以精確到微秒,甚至還可以統(tǒng)計分析系統(tǒng)「調(diào)用的耗時」,這在排查進程假死問題的時候很有用,能幫你發(fā)現(xiàn)進程卡在哪個系統(tǒng)調(diào)用上。已經(jīng)在運行的進程也可以指定-p參數(shù)加pid像gdb attach那樣附著上去跟蹤。

探究進程第三步,讓我看看你帶的小弟們(線程)。

pstack

print a stack trace of a running process 打印出運行中程序的堆棧信息。

執(zhí)行命令pstack pid 你能看到當前線程運行中的堆棧信息,其中的pid可用之前的ps命令獲得,pstack可以看到進程內(nèi)啟動的線程號,每個進程內(nèi)線程的「堆?!箖?nèi)容也能看到。

看到上面打印出的LWP了嗎,這里是個知識點, LPW是指Light-weight process 輕量級線程。引申知識:

Linux中沒有真正的線程

Linux中沒有的線程Thread是由進程來模擬實現(xiàn)的所以稱作:輕量級進程

進程是「資源管理」的最小單元,線程是「資源調(diào)度」的最小單元(這里不考慮協(xié)程)

探究進程第四步,讓小弟們(線程)出來排個隊吧。

pstree

display a tree of processes pstree按樹形結(jié)構(gòu)打印運行中進程結(jié)構(gòu)信息

可以直觀的查看進程和它啟動的線程的關系,并能顯示進程標識。

探究進程第五步,是死(進程崩潰)是活(進程運行中)我都要知道你的秘密(堆棧幀 & 上下文)。

gdb

gdb是GNU開發(fā)的gcc套件中Linux下程序調(diào)試工具,你可以查看程序的堆棧、設置斷點、打印程序運行時信息,甚至還能調(diào)試多線程程序,功能十分強大。

在這里把gdb當成一個命令來講有點大材小用,要詳細說gdb的話,完全可以撐起一篇文章的篇幅,這里長話短說,有機會再開一篇文章詳細介紹下它。

使用

要用gdb調(diào)試C/C++程序首先編譯的時候要加-g選項,g++ -g test.cpp -o test這樣生成的程序就可以用gdb來調(diào)試啦。

可以直接用gdb啟動程序調(diào)試,命令:gdb prog

用gdb附著到一個已經(jīng)啟動的進程上調(diào)試也可以。命令:gdb prog pid

程序崩潰之后參數(shù)corefile也可以用gdb調(diào)試,看看程序死掉之前留了什么遺言(堆棧信息)給你。命令:gdb prog corefile,這里有一點需要注意,有些Linux系統(tǒng)默認程序崩潰不生成corefile,這時你需要ulimit -c unlimited這樣就能生成corefile了。

探究進程第六步,關于你的所有,我都想知道。

更近一步

通過/proc/pid文件了解進程的運行時信息和統(tǒng)計信息。/proc系統(tǒng)是一個偽文件系統(tǒng),它只存在內(nèi)存當中,而不占用外存空間,以文件系統(tǒng)的方式為內(nèi)核與進程提供通信的接口。進入系統(tǒng)/proc目錄:

/proc目錄下有很多以數(shù)字命名的目錄,每個數(shù)字代表進程號PID它們是進程目錄。系統(tǒng)中當前運行的每一個進程在/proc下都對應一個以進程號為目錄名的目錄/proc/pid,它們是讀取進程信息的接口,我們可以進到這個文件里面,了解進程的運行時信息和統(tǒng)計信息。

高頻使用

/proc/pid目錄下的有一些重要文件,挑幾個使用頻率高的講一講。

/proc/pid/environ 包含了進程的可用環(huán)境變量的列表 。程序出問題了如果不確定環(huán)境變量是否設置生效,可以cat這個文件出來查看確認一下。

/proc/pid/fd/ 這個目錄包含了進程打開的每一個文件的鏈接。從這里可以查看進程打開的文件描述符信息,包括標準輸入、輸出、錯誤流,進程打開的socket連接文件描述符也能看到,lsof命令也有類似的作用。

/proc/pid/stat包含了進程的所有狀態(tài)信息,進程號、父進程號、 線程組號、 該任務在用戶態(tài)運行的時間 、 該任務在用內(nèi)核態(tài)運行的時間、 虛擬地址空間的代碼段、 阻塞信號的位圖等等信息應有盡有。

其他統(tǒng)計

/proc/pid/cmdline 包含了用于開始進程的命令

/proc/pid/cwd包含了當前進程工作目錄的一個鏈接

/proc/pid/exe包含了正在進程中運行的程序鏈接

/proc/pid/mem包含了進程在內(nèi)存中的內(nèi)容

/proc/pid/statm包含了進程的內(nèi)存使用信息

總結(jié)一下

好了,一頓操作下來,你對進程和它背后的秘密你已經(jīng)非常了解了,下次我們的好朋友「進程」如果遇到了什么問題(崩潰coredump、假死、阻塞、系統(tǒng)調(diào)用超時、文件描述符異常),你應該知道如何幫它處理了吧!我們來總結(jié)一下:

ps查看進程id,看看進程還在不在以及進程狀態(tài)

如果在的話strace、psstack看下進程當前信息,是不卡死在哪個位置,對比各幀最后調(diào)用信息找到異常點

如果進程不再了,如果有corefile文件,直接上gdb查看corefile信息

其他疑難雜癥懷疑進程狀態(tài)信息的時候,看看/proc/pid下面的進程狀態(tài)信息,可能會給你啟發(fā)。

本站聲明: 本文章由作者或相關機構(gòu)授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

CPU親和度通過限制進程或線程可以運行的CPU核心集合,使得它們只能在指定的CPU核心上執(zhí)行。這可以減少CPU緩存的失效次數(shù),提高緩存命中率,從而提升系統(tǒng)性能。

關鍵字: Linux 嵌入式

一個線程只能屬于一個進程,而一個進程可以有多個線程,線程是進程的一部分,就像工人是工廠的一部分。資源是分配給進程的,同一進程的所有線程共享該進程的全部資源,就像工廠里的工人共享工廠的設備和場地。處理機(CPU)則是分給線...

關鍵字: 進程 線程

DXC內(nèi)部新成立的Boomi卓越中心(COE),將成為跨行業(yè)客戶的創(chuàng)新樞紐 DXC與Boomi攜手助力客戶整合AI智能體,為規(guī)?;瘧么硎紸I做好準備 弗吉尼亞州阿什伯恩2025年8月19日 /美通社/ --名列財...

關鍵字: 進程 AI BSP 自動化

在Linux系統(tǒng)性能優(yōu)化中,內(nèi)存管理與網(wǎng)絡連接處理是兩大核心領域。vm.swappiness與net.core.somaxconn作為關鍵內(nèi)核參數(shù),直接影響系統(tǒng)在高負載場景下的穩(wěn)定性與響應速度。本文通過實戰(zhàn)案例解析這兩個...

關鍵字: Linux 內(nèi)存管理

對于LLM,我使用b谷歌Gemini的免費層,所以唯一的成本是n8n托管。在使用了n8n Cloud的免費積分后,我決定將其托管在Railway上(5美元/月)。然而,由于n8n是開源的,您可以在自己的服務器上托管它,而...

關鍵字: 人工智能 n8n Linux

在Linux系統(tǒng)管理中,權限控制是安全運維的核心。本文通過解析/etc/sudoers文件配置與組策略的深度應用,結(jié)合某金融企業(yè)生產(chǎn)環(huán)境案例(成功攔截98.7%的非法提權嘗試),揭示精細化權限管理的關鍵技術點,包括命令別...

關鍵字: Linux 用戶權限 sudoers文件

Linux內(nèi)核中的信號量(Semaphore)是一種用于資源管理的同步原語,它允許多個進程或線程對共享資源進行訪問控制。信號量的主要作用是限制對共享資源的并發(fā)訪問數(shù)量,從而防止系統(tǒng)過載和數(shù)據(jù)不一致的問題。

關鍵字: Linux 嵌入式

在云計算與容器化技術蓬勃發(fā)展的今天,Linux網(wǎng)絡命名空間(Network Namespace)已成為構(gòu)建輕量級虛擬網(wǎng)絡的核心組件。某頭部互聯(lián)網(wǎng)企業(yè)通過命名空間技術將測試環(huán)境資源消耗降低75%,故障隔離效率提升90%。本...

關鍵字: Linux 云計算

在Linux內(nèi)核4.18+和主流發(fā)行版(RHEL 8/Ubuntu 20.04+)全面轉(zhuǎn)向nftables的背景下,某電商平臺通過遷移將防火墻規(guī)則處理效率提升40%,延遲降低65%。本文基于真實生產(chǎn)環(huán)境案例,詳解從ipt...

關鍵字: nftables Linux

在Linux設備驅(qū)動開發(fā)中,等待隊列(Wait Queue)是實現(xiàn)進程睡眠與喚醒的核心機制,它允許進程在資源不可用時主動放棄CPU,進入可中斷睡眠狀態(tài),待資源就緒后再被喚醒。本文通過C語言模型解析等待隊列的實現(xiàn)原理,結(jié)合...

關鍵字: 驅(qū)動開發(fā) C語言 Linux
關閉