搜尋
首頁運維linux運維Linux平均負載Load問題的詳解
Linux平均負載Load問題的詳解Mar 12, 2019 pm 05:24 PM
linux

這篇文章帶給大家的內容是關於Linux平均負載Load問題的詳解,有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。

有一回面試,面試官提了一個問題,cpu 使用率不高,但是 Load (平均負荷) 很高,你如何找出問題?

當時我不明白 Load 的意思,面試官解釋這個指標反映不可中斷狀態的進程比較多。我遂根據過往後端開發經驗,回答可能係統中io 阻塞比較多,多發於網絡io 問題,用命令 netstat -tnp 看看tcp 連接中time_wait 狀態多不多...

#我知道我的回答很片面,事後複習,做筆記。

什麼是平均負載

熟悉 Linux 者知道,使用 top uptime 指令可以檢視 load average 指標。

使用 man uptime 查看Load average 解釋:

System load averages is the average number of processes that are either in a runnable or uninterruptable state.   A  process  in ables  or waiting to use the CPU.  A process in uninterruptable state is waiting for some I/O access, eg waiting for disk.  The averages are taken over the three time intervals.  Load averages system not avers ined the number intervals.  Load avernorage system not avers injare not avers in the not avers in the not avers in the nad avers in. so a  load average of 1 means a single CPU system is loaded all the time while on a 4 CPU system it means it was idle 75% of the time.

理解關鍵地方,平均負載是指,在單位時間內,系統中處於 可運作狀態 與 不可中斷狀態 的平均行程數,簡稱平均活躍行程數。值得注意的是,它與CPU 使用率沒有直接關係

使用指令 ps aux 可以檢視進程的狀態stat,如本文要注意的:

R 狀態,可運作狀態( Running / Runnable ),正在使用CPU 或正在等待CPU 的進程D 狀態,不可中斷狀態( Uninterruptitle Sleep, 又稱Disk Sleep ),正處於內核態關鍵流程中的進程,並且是不可中斷的。

D 狀態為何不可打斷呢,舉個例子,系統調用起硬體設備的I/O 響應,為了保證數據的一致性,在磁碟設備返回數據前,它是不能倍其他進程或者中斷打斷的,如果被打斷,就容易造成磁碟資料與流程資料不一致的問題。於是,不可中斷(D)狀態是系統對程序與硬體設備的一種保護機制。

平均活躍進程數,嚴格意義上,它是活躍進程數的指數衰減平均值(某個量的下降速度和它的值成比例)。通常情況下,理解為單位時間上的活躍進程數即可。

CPU 使用率與平衡負載

從CPU 角度來說,Load average 只是反映單位時間內佔用CPU 的進程數量,而CPU 使用率與進程數沒有直接關係,我們可以使用指令 top vmstat 查看CPU 的使用率,有以下幾個指標:

%us:表示使用者空間程式的cpu使用率(沒有透過nice調度)%sy:表示系統空間的cpu使用率,主要是內核程式。 %ni:表示用戶空間且透過nice調度過的程式的cpu使用率。 %id:空閒cpu%wa:cpu運作時在等待io的時間%hi:cpu處理硬中斷的數量%si:cpu處理軟中斷的數量%st:被虛擬機偷走的cpu

如何衡量合理的平均負載

一般來講,Load average 低於CPU 數量的話,機器性能滿足服務需求,超出一些也沒關係,Load average 不直接代表CPU 利用率,可能是io 阻塞比較多。當 Load average 高於 CPU 數量的 70%,就可能導致進程回應變慢,進而影響服務的正常功能。

從歷史變化量來看

一般來講,top uptime 提供 load average 三個時間點的指標,分別是:1分鐘、5分鐘、15分鐘。這反映了系統最近的狀態變化趨勢。在實際生產環境中,我們需要做長期的監控記錄。如果有異常的數值變化,例如平均負載數是CPU的兩倍,則需要分析調查問題。

從平衡負載與CPU 使用率這兩類指標綜合分析

兩類指標的不同,組合出下列幾種可能情況:

Load average 高,CPU use 高,要么運行了CPU 密集型進程(線程),要么有大量等待CPU 的進程(線程)調度Load average 高,CPU use 底,運行了IO 密集型進程兩者都比較低,正常Load average 底, CPU use 高,這是不存在的

模擬案例與工具

我們如何分析平衡負載與CPU 使用率這兩類指標不同組合的案例,尋找造成指標變化的來源?

以下環境為Linux Arch 4.19 / 4 CPU / 8G Memory

工具清單

stress 系統壓力測試工具

sysstat 效能分析工具包:

mpstat 多核心 CPU 分析效能工具,mp 的意思是 multi processors (多處理器)pidstat 進程效能分析工具,pid 意為進程 ID。它用於查看進程的CPU、記憶體、I/O以及上下文切換等指標

#模擬場景

#使用stress 可以模擬以下場景

CPU密集型進程

# 模拟一个进程, 对 cpu 使用率 100%,限时 600s
stress --cpu 1 --timeout 600

IO 密集型進程

stress 的 -i 選項,spawn N workers spinning on sync()

# 模拟一个进程不停的执行 sync
stress -i 1 --timeout 600
大量進程的場景
# 模拟16个进程, 对 cpu 使用率 100%,限时 600s
stress --cpu 16 --timeout 600

工具指標

mpstat -P ALL 5 監控所有CPU,每隔5秒輸出一組數據,注意指標 %usr 使用率,%iowait IO 阻塞時間,從這可以判斷是CPU 密集型還是IO 密集型pidstat - u 5 1 統計間隔5秒內,使用過CPU 的進程的數據,注意指標 %usr 使用率,%wait 等待使用CPU 的時間,從這可以判斷是否進程(線程)過多

以上是Linux平均負載Load問題的詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:segmentfault。如有侵權,請聯絡admin@php.cn刪除
什么是linux设备节点什么是linux设备节点Apr 18, 2022 pm 08:10 PM

linux设备节点是应用程序和设备驱动程序沟通的一个桥梁;设备节点被创建在“/dev”,是连接内核与用户层的枢纽,相当于硬盘的inode一样的东西,记录了硬件设备的位置和信息。设备节点使用户可以与内核进行硬件的沟通,读写设备以及其他的操作。

Linux中open和fopen的区别有哪些Linux中open和fopen的区别有哪些Apr 29, 2022 pm 06:57 PM

区别:1、open是UNIX系统调用函数,而fopen是ANSIC标准中的C语言库函数;2、open的移植性没fopen好;3、fopen只能操纵普通正规文件,而open可以操作普通文件、网络套接字等;4、open无缓冲,fopen有缓冲。

linux中什么叫端口映射linux中什么叫端口映射May 09, 2022 pm 01:49 PM

端口映射又称端口转发,是指将外部主机的IP地址的端口映射到Intranet中的一台计算机,当用户访问外网IP的这个端口时,服务器自动将请求映射到对应局域网内部的机器上;可以通过使用动态或固定的公共网络IP路由ADSL宽带路由器来实现。

什么是linux交叉编译什么是linux交叉编译Apr 29, 2022 pm 06:47 PM

在linux中,交叉编译是指在一个平台上生成另一个平台上的可执行代码,即编译源代码的平台和执行源代码编译后程序的平台是两个不同的平台。使用交叉编译的原因:1、目标系统没有能力在其上进行本地编译;2、有能力进行源代码编译的平台与目标平台不同。

linux中eof是什么linux中eof是什么May 07, 2022 pm 04:26 PM

在linux中,eof是自定义终止符,是“END Of File”的缩写;因为是自定义的终止符,所以eof就不是固定的,可以随意的设置别名,linux中按“ctrl+d”就代表eof,eof一般会配合cat命令用于多行文本输出,指文件末尾。

linux怎么判断pcre是否安装linux怎么判断pcre是否安装May 09, 2022 pm 04:14 PM

在linux中,可以利用“rpm -qa pcre”命令判断pcre是否安装;rpm命令专门用于管理各项套件,使用该命令后,若结果中出现pcre的版本信息,则表示pcre已经安装,若没有出现版本信息,则表示没有安装pcre。

linux怎么查询mac地址linux怎么查询mac地址Apr 24, 2022 pm 08:01 PM

linux查询mac地址的方法:1、打开系统,在桌面中点击鼠标右键,选择“打开终端”;2、在终端中,执行“ifconfig”命令,查看输出结果,在输出信息第四行中紧跟“ether”单词后的字符串就是mac地址。

linux中rpc是什么意思linux中rpc是什么意思May 07, 2022 pm 04:48 PM

在linux中,rpc是远程过程调用的意思,是Reomote Procedure Call的缩写,特指一种隐藏了过程调用时实际通信细节的IPC方法;linux中通过RPC可以充分利用非共享内存的多处理器环境,提高系统资源的利用率。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前By尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前By尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
4 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具