Linux Accounting(中文翻譯): Delay Accounting

来源:https://www.cnblogs.com/aosp/archive/2022/06/15/16369720.html
-Advertisement-
Play Games

Delay accounting 延時統計 任務在執行時等待某個內核資源會意外遇到延遲,例如可運行的任務正在等待空閑CPU。 per-task的延時統計功能測量下列情況下任務經歷的延遲: 正在等待CPU,waiting for a CPU (while being runnable) 同步塊I/O的 ...


Delay accounting

延時統計

任務在執行時等待某個內核資源會意外遇到延遲,例如可運行的任務正在等待空閑CPU。

per-task的延時統計功能測量下列情況下任務經歷的延遲:

  • 正在等待CPU,waiting for a CPU (while being runnable)
  • 同步塊I/O的完成,completion of synchronous block I/O initiated by the task
  • 正在頁面內交換,swapping in pages
  • 記憶體回收,memory reclaim
  • 占滿頁面緩存,thrashing page cache
  • 直接壓縮,direct compact
  • 防寫拷貝,write-protect copy
    這些統計功能通過taskstats介面提供給用戶空間使用。

這些延遲給設置CPU優先順序,IO優先順序和合適的RSS限制提供了反饋。重要任務的長期延遲可以作為一個觸發器來提高它的優先順序。

這個功能,通過使用taskstats介面,也為所有的線程組(傳統的UNIX進程)中的任務或者線程提供了延時統計,這種收集比內核收集更有效。

用戶空間的應用,特別是資源管理應用程式,也能收集延遲統計到任意分組。要使能這個功能,任務的延遲統計能在整個生存周期內和退出時都可用,需要保證連續的和完全的監測。

介面

延遲統計使用的taskstats介面在本目錄下的文檔中被詳細地描述。Taskstats給用戶空間返回一個per-pid和per-tgid統計的通用數據結構。延遲統計功能計算這個結構中的具體數據域。參看include/uapi/linux/taskstats.h中的與延遲統計有關的數據域描述。

它一般以計數器的形式返回累計延遲(for cpu, sync block I/O, swapin, memory reclaim, thrash page cache, direct compact, write-protect copy等)。

獲取任務計數器(cpu_delay_total)的兩個連續讀數的差異,由於等待這個間隔內的相關資源也會帶來任務延遲。

當任務退出時,per-task統計的記錄被髮送給用戶空間。如果它是線程組中最後退出的任務,per-tgid統計也會被髮送。更多細節由taskstats介面描述給出。

在tools/accounting目錄下的用戶空間程式getdelays.c允許運行簡單的命令和顯示相關的延遲統計信息。它也用作taskstats的簡單示例。

使用

編譯內核:

CONFIG_TASK_DELAY_ACCT=y
CONFIG_TASKSTATS=y

延遲統計啟動時預設是禁止的,要使能它,增加delayacct到內核啟動選項。要麼使用sysctl kernel.task_delayacct在運行時來切換狀態。註意只要在使能之後啟動任務,它就有delayacct信息。

系統系統之後,使用跟getdelays.c相似的程式來訪問任務或者任務組(tgid)相關的延遲。應用程式也允許執行命令和查看相關的延遲。

getdelays命令的一般格式:

getdelays [-dilv] [-t tgid] [-p pid]

獲取自系統啟動以來PID 10的延遲:

# ./getdelays -d -p 10
(output similar to next case)

獲取自系統啟動以來tgid 5中所有pid的延遲總和:

# ./getdelays -d -t 5
print delayacct stats ON
TGID    5

CPU             count     real total  virtual total    delay total  delay average
                    8        7000000        6872122        3382277          0.423ms
IO              count    delay total  delay average
                    0              0              0ms
SWAP            count    delay total  delay average
                    0              0              0ms
RECLAIM         count    delay total  delay average
                    0              0              0ms
THRASHING       count    delay total  delay average
                    0              0              0ms
COMPACT         count    delay total  delay average
                    0              0              0ms
WPCOPY          count    delay total  delay average
                    0              0              0ms

獲取pid1的IO統計:

# ./getdelays -i -p 1
printing IO accounting
linuxrc: read=65536, write=0, cancelled_write=0

上述命令可以使用-v來獲取等多調試信息。


英文原文:
https://www.kernel.org/doc/html/latest/accounting/delay-accounting.html


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

-Advertisement-
Play Games
更多相關文章
  • 我本地寫了一個rabbitmq fanout模式的demo。consumer啟動類和producer啟動類都放到了一個springboot程式里。本地調試通過。 突然有個疑問,springboot項目是怎麼來發現主啟動類的呢? 我們知道,預設使用maven打包時,是個普通的可供依賴的jar包,僅包含 ...
  • referer,正確寫法referrer,指的是網站的一種安全策略,在請求頭CSP(Content-Security-Policy),標簽或者是指定的html標簽里都可以設置它,它指的是上一個請求的來源記錄,比如你從a1通過鏈連,跳到a2,那在a2的請求頭裡,就會有a1的網址或者功能變數名稱,這個和refe ...
  • 項目中經常遇到CSV文件的讀寫需求,其中的難點主要是CSV文件的解析。本文會介紹CsvHelper、TextFieldParser、正則表達式三種解析CSV文件的方法,順帶也會介紹一下CSV文件的寫方法。 CSV文件標準 在介紹CSV文件的讀寫方法前,我們需要瞭解一下CSV文件的格式。 文件示例 一 ...
  • 這幾天在看 C++ 的 lambda 表達式,挺有意思,這個標準是在 C11標準 加進去的,也就是 2011 年,相比 C# 2007 還晚了個 4 年, Lambda 這東西非常好用,會上癮,今天我們簡單聊一聊。 一:語法定義 首先我們看下 C++ 語法定義格式: [capture] (param ...
  • 在Winform開發中有時候我們為了不影響主UI線程的處理,以前我們使用後臺線程BackgroundWorker來處理一些任務操作,不過隨著非同步處理提供的便利性,我們可以使用Async-Awati非同步任務處理替換原來的後臺線程BackgroundWorker處理方式,更加的簡潔明瞭。 ...
  • WPF(Windows Presentation Foundation)是微軟推出的基於Windows 的用戶界面框架,由 .NET Framework 3.0 開始引入,與WCF (Windows Communication Foundation)及 WF(Windows Workflow Fou... ...
  • 在我們對數據進行重要修改調整的時候,往往需要跟蹤記錄好用戶操作日誌。一般來說,如對重要表記錄的插入、修改、刪除都需要記錄下來,由於用戶操作日誌會帶來一定的額外消耗,因此我們通過配置的方式來決定記錄那些業務數據的重要調整。本篇隨筆介紹如何在基於SqlSugar的開發框架中,實現對用戶操作日誌記錄的配置... ...
  • 目錄 一、前景回顧 二、物理地址、線性地址和虛擬地址 三、記憶體為什麼要分頁 四、一級頁表 五、二級頁表 一、前景回顧 前面我們說到,保護模式下有著三大特點:地址映射、特權級和分時機制。從我的學習角度來說,我認為地址映射這一塊的知識點尤為繁雜,所以會花費相對比較多的時間來講述,話不多說,開整。 二、物 ...
一周排行
    -Advertisement-
    Play Games
  • 概述:本文代碼示例演示瞭如何在WPF中使用LiveCharts庫創建動態條形圖。通過創建數據模型、ViewModel和在XAML中使用`CartesianChart`控制項,你可以輕鬆實現圖表的數據綁定和動態更新。我將通過清晰的步驟指南包括詳細的中文註釋,幫助你快速理解並應用這一功能。 先上效果: 在 ...
  • openGauss(GaussDB ) openGauss是一款全面友好開放,攜手伙伴共同打造的企業級開源關係型資料庫。openGauss採用木蘭寬鬆許可證v2發行,提供面向多核架構的極致性能、全鏈路的業務、數據安全、基於AI的調優和高效運維的能力。openGauss深度融合華為在資料庫領域多年的研 ...
  • openGauss(GaussDB ) openGauss是一款全面友好開放,攜手伙伴共同打造的企業級開源關係型資料庫。openGauss採用木蘭寬鬆許可證v2發行,提供面向多核架構的極致性能、全鏈路的業務、數據安全、基於AI的調優和高效運維的能力。openGauss深度融合華為在資料庫領域多年的研 ...
  • 概述:本示例演示了在WPF應用程式中實現多語言支持的詳細步驟。通過資源字典和數據綁定,以及使用語言管理器類,應用程式能夠在運行時動態切換語言。這種方法使得多語言支持更加靈活,便於維護,同時提供清晰的代碼結構。 在WPF中實現多語言的一種常見方法是使用資源字典和數據綁定。以下是一個詳細的步驟和示例源代 ...
  • 描述(做一個簡單的記錄): 事件(event)的本質是一個委托;(聲明一個事件: public event TestDelegate eventTest;) 委托(delegate)可以理解為一個符合某種簽名的方法類型;比如:TestDelegate委托的返回數據類型為string,參數為 int和 ...
  • 1、AOT適合場景 Aot適合工具類型的項目使用,優點禁止反編 ,第一次啟動快,業務型項目或者反射多的項目不適合用AOT AOT更新記錄: 實實在在經過實踐的AOT ORM 5.1.4.117 +支持AOT 5.1.4.123 +支持CodeFirst和非同步方法 5.1.4.129-preview1 ...
  • 總說周知,UWP 是運行在沙盒裡面的,所有許可權都有嚴格限制,和沙盒外交互也需要特殊的通道,所以從根本杜絕了 UWP 毒瘤的存在。但是實際上 UWP 只是一個應用模型,本身是沒有什麼許可權管理的,許可權管理全靠 App Container 沙盒控制,如果我們脫離了這個沙盒,UWP 就會放飛自我了。那麼有沒... ...
  • 目錄條款17:讓介面容易被正確使用,不易被誤用(Make interfaces easy to use correctly and hard to use incorrectly)限制類型和值規定能做和不能做的事提供行為一致的介面條款19:設計class猶如設計type(Treat class de ...
  • title: 從零開始:Django項目的創建與配置指南 date: 2024/5/2 18:29:33 updated: 2024/5/2 18:29:33 categories: 後端開發 tags: Django WebDev Python ORM Security Deployment Op ...
  • 1、BOM對象 BOM:Broswer object model,即瀏覽器提供我們開發者在javascript用於操作瀏覽器的對象。 1.1、window對象 視窗方法 // BOM Browser object model 瀏覽器對象模型 // js中最大的一個對象.整個瀏覽器視窗出現的所有東西都 ...