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
  • 前言 在我們開發過程中基本上不可或缺的用到一些敏感機密數據,比如SQL伺服器的連接串或者是OAuth2的Secret等,這些敏感數據在代碼中是不太安全的,我們不應該在源代碼中存儲密碼和其他的敏感數據,一種推薦的方式是通過Asp.Net Core的機密管理器。 機密管理器 在 ASP.NET Core ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 順序棧的介面程式 目錄順序棧的介面程式頭文件創建順序棧入棧出棧利用棧將10進位轉16進位數驗證 頭文件 #include <stdio.h> #include <stdbool.h> #include <stdlib.h> 創建順序棧 // 指的是順序棧中的元素的數據類型,用戶可以根據需要進行修改 ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • C總結與剖析:關鍵字篇 -- <<C語言深度解剖>> 目錄C總結與剖析:關鍵字篇 -- <<C語言深度解剖>>程式的本質:二進位文件變數1.變數:記憶體上的某個位置開闢的空間2.變數的初始化3.為什麼要有變數4.局部變數與全局變數5.變數的大小由類型決定6.任何一個變數,記憶體賦值都是從低地址開始往高地 ...
  • 如果讓你來做一個有狀態流式應用的故障恢復,你會如何來做呢? 單機和多機會遇到什麼不同的問題? Flink Checkpoint 是做什麼用的?原理是什麼? ...
  • C++ 多級繼承 多級繼承是一種面向對象編程(OOP)特性,允許一個類從多個基類繼承屬性和方法。它使代碼更易於組織和維護,並促進代碼重用。 多級繼承的語法 在 C++ 中,使用 : 符號來指定繼承關係。多級繼承的語法如下: class DerivedClass : public BaseClass1 ...
  • 前言 什麼是SpringCloud? Spring Cloud 是一系列框架的有序集合,它利用 Spring Boot 的開發便利性簡化了分散式系統的開發,比如服務註冊、服務發現、網關、路由、鏈路追蹤等。Spring Cloud 並不是重覆造輪子,而是將市面上開發得比較好的模塊集成進去,進行封裝,從 ...
  • class_template 類模板和函數模板的定義和使用類似,我們已經進行了介紹。有時,有兩個或多個類,其功能是相同的,僅僅是數據類型不同。類模板用於實現類所需數據的類型參數化 template<class NameType, class AgeType> class Person { publi ...
  • 目錄system v IPC簡介共用記憶體需要用到的函數介面shmget函數--獲取對象IDshmat函數--獲得映射空間shmctl函數--釋放資源共用記憶體實現思路註意 system v IPC簡介 消息隊列、共用記憶體和信號量統稱為system v IPC(進程間通信機制),V是羅馬數字5,是UNI ...