Linux 基礎-查看進程命令 ps 和 top

来源:https://www.cnblogs.com/armcvai/archive/2022/11/25/16926562.html
-Advertisement-
Play Games

在所有監控 Linux 系統性能的工具中,Linux 的 top 命令是最好的也是最知名的一個(htop 是其升級版)。top 命令提供了 Linux 系統運行中的進程的動態實時視圖。它能顯示系統的概覽信息和 Linux 內核當前管理的進程列表。它顯示了大量的系統信息,如 CPU 使用、記憶體使用、交... ...


Linux 基礎-查看進程命令 ps 和 top

1,使用 ps 命令找出 CPU 占用高的進程

ps 是 進程狀態 (process status) 的縮寫,它能顯示系統中活躍的/運行中的進程的信息。它提供了當前進程及其詳細信息,諸如用戶名、用戶 IDCPU 使用率、記憶體使用、進程啟動日期時間、命令名等等的快照。只列印命令名字而不是命令的絕對路徑,以運行下麵的格式 ps 命令:

~$ ps -eo pid,ppid,%mem,%cpu,comm --sort=-%cpu | head

運行結果如下:

image

上面命令語句的各部分參數解釋:

  • ps:命令名字
  • -e:選擇所有進程
  • -o:自定義輸出格式
  • –sort=-%cpu:基於 CPU 使用率對輸出結果排序
  • head:顯示結果的前 10 行
  • PID:進程的 ID
  • PPID:父進程的 ID
  • %MEM:進程使用的 RAM 比例
  • %CPU:進程占用的 CPU 比例
  • Command:進程名字

2,通過 top 命令定位占用 cpu 高的進程

  • 查看 cpu 占用最高進程(查看前3位):top,然後按下 M(大寫 M)。
  • 查看記憶體占用最高進程:top,然後按下 P(大寫 P )。
  • 可視化查看所有用戶所有進程使用情況:ps axf

在所有監控 Linux 系統性能的工具中,Linuxtop 命令是最好的也是最知名的一個(htop 是其升級版)。top 命令提供了 Linux 系統運行中的進程的動態實時視圖。它能顯示系統的概覽信息和 Linux 內核當前管理的進程列表。它顯示了大量的系統信息,如 CPU 使用、記憶體使用、交換記憶體、運行的進程數、目前系統開機時間、系統負載、緩衝區大小、緩存大小、進程 PID 等等。預設情況下,top 命令的輸出結果按 CPU 占用進行排序,每 5 秒中更新一次結果。

ps -ef                 # 查看所有進程
top                    # 實時顯示進程狀態

Linux 系統下執行 top 命令得到以下結果(第一列為進程的 PID,第二列為進程所屬用戶):

image

上圖各個參數的意義:

  • PID:進程的ID
  • USER:進程所有者
  • PR:進程的優先順序別,越小越優先被執行
  • NInice:值
  • VIRT:進程占用的虛擬記憶體
  • RES:進程占用的物理記憶體
  • SHR:進程使用的共用記憶體
  • S:進程的狀態。S表示休眠,R表示正在運行,Z表示僵死狀態,N表示該進程優先值為負數
  • %CPU:進程占用CPU的使用率
  • %MEM:進程使用的物理記憶體和總記憶體的百分比
  • TIME+:該進程啟動後占用的總的CPU時間,即占用CPU使用時間的累加值。
  • COMMAND:進程啟動命令名稱

通過上圖可以看出排在一行的進程 PID 2438占用 cpu 過高,定位到了進程 id。如果只想觀察 進程PID 2438的 CPU和記憶體以及負載情況,可以使用以下命令:

top -p 2438

結果如下:

image

還可以通過 top 命令定位問題進程中每個線程占用 cpu 情況,如查看進程 PID 2438 的每一個線程占用 cpu 的情況,使用如下命令:

top -p 2438 -H

結果如下(單線程,所以只顯示一行):

image

3,htop 系統監控與進程管理軟體

top 只提供最消耗資源的進程列表不同,htop 提供所有進程的列表,並且使用彩色標識出處理器、swap 和記憶體狀態。可以通過 htop 查看單個進程的線程,然後按 <F2> 來進入 htop 的設置菜單。選擇“設置”欄下麵的“顯示選項”,然後開啟“樹狀視圖”和“顯示自定義線程名”選項。按 <F10> 退出設置。

image

image

4,參考資料

線上linux系統故障排查之一:CPU使用率過高


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 對於緩存容器而言,容量限制與數據淘汰是兩個基礎且核心的關鍵點,也是實際使用的時候使用頻率最高的特性。本篇在上一文基礎上深入解讀下Guava Cache中的容量限制與數據淘汰策略的實現與使用約束。 ...
  • Spring,作為 Java EE 的事實規範,在2022年11月16日發佈了最新的 6.0.0 GA 版本。這個版本是框架後續新生代的初始版本,擁抱持續創新的 OpenJDK 和 Java 生態。新的版本以 Java 17+ 作為 baseline,並遷移至 Jakarta EE 9+(即,使用 ...
  • 作者:寧海翔 1 前言 對象拷貝,是我們在開發過程中,繞不開的過程,既存在於Po、Dto、Do、Vo各個表現層數據的轉換,也存在於系統交互如序列化、反序列化。 Java對象拷貝分為深拷貝和淺拷貝,目前常用的屬性拷貝工具,包括Apache的BeanUtils、Spring的BeanUtils、Cgli ...
  • 用python爬蟲技術,爬取百度搜索結果數據,包含欄位: 頁碼、標題、百度鏈接、真實鏈接、簡介、網站名稱。 並把源碼封裝成exe文件,方便沒有python環境,或者不懂技術的人使用它。 ...
  • 上篇隨筆發佈後,一天內,十幾個爬蟲網站爬取了我的隨筆,有些網站非但沒有註明來源,反而將自己標為博文的原創者,並更改了圖像水印,這篇被爬的隨筆雖瀏覽量不大,但好歹是自己一字一字認真碼出來的,被偷實在令人心情不爽,在本篇隨筆記錄一下。 ...
  • WebDAV 是超文本傳輸協議 (HTTP) 的一組擴展,為 Internet 上電腦之間的編輯和文件管理提供了標準.利用這個協議用戶可以通過Web進行遠程的基本文件操作,如拷貝、移動、刪除等。 在IIS 7.0中,WebDAV是作為獨立擴展模塊,需要單獨進行下載,而IIS 7.5以及以上版本中... ...
  • .NET 現在支持跨平臺這件事情已經是眾所周知的特點了,雖然平臺整體支持跨平臺了,但是我們的代碼如果真的想要實現跨平臺運行其實還是有些小細節要註意的,今天想要記錄分享的就是關於 文件I/O操作時路徑的拼接問題。 在 Windows 環境下我們常見的路徑格式如下: D:\Software\AppDat ...
  • 本文是 《精讀 Mastering ABP Framework》 2.3 探索橫切關註點 - 使用授權和許可權系統 一節的擴充內容,重點探討了授權在分散式和微服務系統中遇到的挑戰,以及 ABP Framework 中採用的解決方案。 ...
一周排行
    -Advertisement-
    Play Games
  • GoF之工廠模式 @目錄GoF之工廠模式每博一文案1. 簡單說明“23種設計模式”1.2 介紹工廠模式的三種形態1.3 簡單工廠模式(靜態工廠模式)1.3.1 簡單工廠模式的優缺點:1.4 工廠方法模式1.4.1 工廠方法模式的優缺點:1.5 抽象工廠模式1.6 抽象工廠模式的優缺點:2. 總結:3 ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 本章將和大家分享ES的數據同步方案和ES集群相關知識。廢話不多說,下麵我們直接進入主題。 一、ES數據同步 1、數據同步問題 Elasticsearch中的酒店數據來自於mysql資料庫,因此mysql數據發生改變時,Elasticsearch也必須跟著改變,這個就是Elasticsearch與my ...
  • 引言 在我們之前的文章中介紹過使用Bogus生成模擬測試數據,今天來講解一下功能更加強大自動生成測試數據的工具的庫"AutoFixture"。 什麼是AutoFixture? AutoFixture 是一個針對 .NET 的開源庫,旨在最大程度地減少單元測試中的“安排(Arrange)”階段,以提高 ...
  • 經過前面幾個部分學習,相信學過的同學已經能夠掌握 .NET Emit 這種中間語言,並能使得它來編寫一些應用,以提高程式的性能。隨著 IL 指令篇的結束,本系列也已經接近尾聲,在這接近結束的最後,會提供幾個可供直接使用的示例,以供大伙分析或使用在項目中。 ...
  • 當從不同來源導入Excel數據時,可能存在重覆的記錄。為了確保數據的準確性,通常需要刪除這些重覆的行。手動查找並刪除可能會非常耗費時間,而通過編程腳本則可以實現在短時間內處理大量數據。本文將提供一個使用C# 快速查找並刪除Excel重覆項的免費解決方案。 以下是實現步驟: 1. 首先安裝免費.NET ...
  • C++ 異常處理 C++ 異常處理機制允許程式在運行時處理錯誤或意外情況。它提供了捕獲和處理錯誤的一種結構化方式,使程式更加健壯和可靠。 異常處理的基本概念: 異常: 程式在運行時發生的錯誤或意外情況。 拋出異常: 使用 throw 關鍵字將異常傳遞給調用堆棧。 捕獲異常: 使用 try-catch ...
  • 優秀且經驗豐富的Java開發人員的特征之一是對API的廣泛瞭解,包括JDK和第三方庫。 我花了很多時間來學習API,尤其是在閱讀了Effective Java 3rd Edition之後 ,Joshua Bloch建議在Java 3rd Edition中使用現有的API進行開發,而不是為常見的東西編 ...
  • 框架 · 使用laravel框架,原因:tp的框架路由和orm沒有laravel好用 · 使用強制路由,方便介面多時,分多版本,分文件夾等操作 介面 · 介面開發註意欄位類型,欄位是int,查詢成功失敗都要返回int(對接java等強類型語言方便) · 查詢介面用GET、其他用POST 代碼 · 所 ...
  • 正文 下午找企業的人去鎮上做貸後。 車上聽同事跟那個司機對罵,火星子都快出來了。司機跟那同事更熟一些,連我在內一共就三個人,同事那一手指桑罵槐給我都聽愣了。司機也是老社會人了,馬上聽出來了,為那個無辜的企業經辦人辯護,實際上是為自己辯護。 “這個事情你不能怪企業。”“但他們總不能讓銀行的人全權負責, ...