国产成人精品18p,天天干成人网,无码专区狠狠躁天天躁,美女脱精光隐私扒开免费观看

Linux上使用什么命令來(lái)管理進(jìn)程

發(fā)布時(shí)間:2021-09-14 18:13 來(lái)源:億速云 閱讀:0 作者:chen 欄目: 服務(wù)器 歡迎投稿:712375056

本篇內容主要講解“Linux上使用什么命令來(lái)管理進(jìn)程”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強。下面就讓小編來(lái)帶大家學(xué)習“Linux上使用什么命令來(lái)管理進(jìn)程”吧!



在 Linux 中,每個(gè)程序和守護程序daemon都是一個(gè)“進(jìn)程process”。   大多數進(jìn)程代表一個(gè)正在運行的程序。而另外一些程序可以派生出其他進(jìn)程,比如說(shuō)它會(huì )偵聽(tīng)某些事件的發(fā)生,然后對其做出響應。并且每個(gè)進(jìn)程都需要一定的內存和處理能力。你運行的進(jìn)程越多,所需的內存和  CPU 使用周期就越多。在老式電腦(例如我使用了 7  年的筆記本電腦)或輕量級計算機(例如樹(shù)莓派)上,如果你關(guān)注過(guò)后臺運行的進(jìn)程,就能充分利用你的系統。

你可以使用 ps 命令來(lái)查看正在運行的進(jìn)程。你通常會(huì )使用 ps 命令的參數來(lái)顯示出更多的輸出信息。我喜歡使用 -e 參數來(lái)查看每個(gè)正在運行的進(jìn)程,以及 -f 參數來(lái)獲得每個(gè)進(jìn)程的全部細節。以下是一些例子:

$ ps    PID TTY          TIME CMD  88000 pts/0    00:00:00 bash  88052 pts/0    00:00:00 ps  88053 pts/0    00:00:00 head
$ ps -e | head    PID TTY          TIME CMD      1 ?        00:00:50 systemd      2 ?        00:00:00 kthreadd      3 ?        00:00:00 rcu_gp      4 ?        00:00:00 rcu_par_gp      6 ?        00:00:02 kworker/0:0H-events_highpri      9 ?        00:00:00 mm_percpu_wq     10 ?        00:00:01 ksoftirqd/0     11 ?        00:00:12 rcu_sched     12 ?        00:00:00 migration/0
$ ps -ef | headUID          PID    PPID  C STIME TTY          TIME CMDroot           1       0  0 13:51 ?        00:00:50 /usr/lib/systemd/systemd --switched-root --system --deserialize 36root           2       0  0 13:51 ?        00:00:00 [kthreadd]root           3       2  0 13:51 ?        00:00:00 [rcu_gp]root           4       2  0 13:51 ?        00:00:00 [rcu_par_gp]root           6       2  0 13:51 ?        00:00:02 [kworker/0:0H-kblockd]root           9       2  0 13:51 ?        00:00:00 [mm_percpu_wq]root          10       2  0 13:51 ?        00:00:01 [ksoftirqd/0]root          11       2  0 13:51 ?        00:00:12 [rcu_sched]root          12       2  0 13:51 ?        00:00:00 [migration/0]

最后的例子顯示最多的細節。在每一行,UID(用戶(hù) ID)顯示了該進(jìn)程的所有者。PID(進(jìn)程 ID)代表每個(gè)進(jìn)程的數字 ID,而 PPID(父進(jìn)程 ID)表示其父進(jìn)程的數字 ID。在任何 Unix 系統中,進(jìn)程是從 1 開(kāi)始編號,是內核啟動(dòng)后運行的第一個(gè)進(jìn)程。在這里,systemd 是第一個(gè)進(jìn)程,它催生了 kthreadd,而 kthreadd 還創(chuàng )建了其他進(jìn)程,包括 rcu_gp、rcu_par_gp 等一系列進(jìn)程。

使用 kill 命令來(lái)管理進(jìn)程

系統會(huì )處理大多數后臺進(jìn)程,所以你不需要操心這些進(jìn)程。你只需要關(guān)注那些你所運行的應用創(chuàng )建的進(jìn)程。雖然許多應用一次只運行一個(gè)進(jìn)程(如音樂(lè )播放器、終端模擬器或游戲等),但其他應用則可能創(chuàng )建后臺進(jìn)程。其中一些應用可能當你退出后還在后臺運行,以便下次你使用的時(shí)候能快速啟動(dòng)。

當我運行 Chromium(作為谷歌 Chrome 瀏覽器所基于的開(kāi)源項目)時(shí),進(jìn)程管理便成了問(wèn)題。 Chromium 在我的筆記本電腦上運行非常吃力,并產(chǎn)生了許多額外的進(jìn)程?,F在我僅打開(kāi)五個(gè)選項卡,就能看到這些 Chromium 進(jìn)程:

$ ps -ef | fgrep chromiumjhall      66221   [...]  /usr/lib64/chromium-browser/chromium-browser [...]jhall      66230   [...]  /usr/lib64/chromium-browser/chromium-browser [...][...]jhall      66861   [...]  /usr/lib64/chromium-browser/chromium-browser [...]jhall      67329   65132  0 15:45 pts/0    00:00:00 grep -F chromium

我已經(jīng)省略一些行,其中有 20 個(gè) Chromium 進(jìn)程和一個(gè)正在搜索 “chromium" 字符的 grep 進(jìn)程。

$ ps -ef | fgrep chromium | wc -l21

但是在我退出 Chromium 之后,這些進(jìn)程仍舊運行。如何關(guān)閉它們并回收這些進(jìn)程占用的內存和 CPU 呢?

kill 命令能讓你終止一個(gè)進(jìn)程。在最簡(jiǎn)單的情況下,你告訴 kill 命令終止你想終止的進(jìn)程的 PID。例如,要終止這些進(jìn)程,我需要對 20 個(gè) Chromium 進(jìn)程 ID 都執行 kill 命令。一種方法是使用命令行獲取 Chromium 的 PID,而另一種方法針對該列表運行 kill

$ ps -ef | fgrep /usr/lib64/chromium-browser/chromium-browser | awk '{print $2}'662216623066239662576626266283662846628566324663376636066370663866640266503665396659566734668486686169702 $ ps -ef | fgrep /usr/lib64/chromium-browser/chromium-browser | awk '{print $2}' > /tmp/pids$ kill $(cat /tmp/pids)

最后兩行是關(guān)鍵。第一個(gè)命令行為 Chromium 瀏覽器生成一個(gè)進(jìn)程 ID 列表。第二個(gè)命令行針對該進(jìn)程 ID 列表運行 kill 命令。

介紹 killall 命令

一次終止多個(gè)進(jìn)程有個(gè)更簡(jiǎn)單方法,使用 killall 命令。你或許可以根據名稱(chēng)猜測出,killall 會(huì )終止所有與該名字匹配的進(jìn)程。這意味著(zhù)我們可以使用此命令來(lái)停止所有流氓 Chromium 進(jìn)程。這很簡(jiǎn)單:

$ killall /usr/lib64/chromium-browser/chromium-browser

但是要小心使用 killall。該命令能夠終止與你所給出名稱(chēng)相匹配的所有進(jìn)程。這就是為什么我喜歡先使用 ps -ef 命令來(lái)檢查我正在運行的進(jìn)程,然后針對要停止的命令的準確路徑運行 killall。

你也可以使用 -i 或 --interactive 參數,來(lái)讓 killkill 在停止每個(gè)進(jìn)程之前提示你。

killall 還支持使用 -o 或 --older-than 參數來(lái)查找比特定時(shí)間更早的進(jìn)程。例如,如果你發(fā)現了一組已經(jīng)運行了好幾天的惡意進(jìn)程,這將會(huì )很有幫助。又或是,你可以查找比特定時(shí)間更晚的進(jìn)程,例如你最近啟動(dòng)的失控進(jìn)程。使用 -y 或 --young-than 參數來(lái)查找這些進(jìn)程。

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng )、來(lái)自本網(wǎng)站內容采集于網(wǎng)絡(luò )互聯(lián)網(wǎng)轉載等其它媒體和分享為主,內容觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如侵犯了原作者的版權,請告知一經(jīng)查實(shí),將立刻刪除涉嫌侵權內容,聯(lián)系我們QQ:712375056,同時(shí)歡迎投稿傳遞力量。

亚洲AV中文无码字幕色三| 真实的国产乱XXXX| 中文字幕一区在线观看视频| 97人洗澡人人澡人人爽人人模| 国产区精品一区二区不卡中文| 亚洲午夜福利精品无码不卡|