測量裝置的記憶體用量

ffx profile memory 指令可測量 Fuchsia 系統的 RAM (隨機存取記憶體) 用量。

概念

ffx profile memory 指令會評估 Fuchsia 系統中 VMOs (Virtual Memory Objects) 的記憶體用量。與 Linux 的 ps 指令不同,這個指令會評估是否對應所有 VMO。

以下範例說明 ffx profile memory 擷取的處理程序記憶體用量:

Process name: core.cm
Process koid: 26387
Private:      268 KiB
PSS:          650.72 KiB (Proportional Set Size)
Total:        4.73 MiB (Private + Shared unscaled)
                              Private       Scaled        Total
    [scudo]                    60 KiB       60 KiB       60 KiB
    [data]                     56 KiB       56 KiB       56 KiB
    [relro]                    56 KiB       56 KiB       56 KiB
    bss:blob-e243d9eb          56 KiB       56 KiB       56 KiB
    [stacks]                   28 KiB       28 KiB       28 KiB
    AllocatorRingBuffer         4 KiB        4 KiB        4 KiB
    [libraries]                 4 KiB        4 KiB        4 KiB
    stack: msg of 0x1000        4 KiB        4 KiB        4 KiB
    [blobs]                       0 B   382.22 KiB     4.41 MiB     (shared)
    vdso/next                     0 B        338 B       40 KiB     (shared)
    vdso/stable                   0 B        170 B       20 KiB     (shared)

在 Fuchsia 中,多個程序可以擁有相同 VMO 的句柄,因此可以共用記憶體。因此,在某些情況下,區分私人記憶體和共用記憶體會很有幫助。為區別,ffx profile memory 會回報處理程序的記憶體用量,分為 3 個不同但重疊的部分:

  • Private 是 VMO 及其子項 VMO 的總大小,這個程序專門保留此程序。
  • Scaled 是 VMO 及其子項 VMO 的總大小,由多個程序保留。這些 VMOs 的費用會平均分配給保留程序。舉例來說,5 個程序共用 500 KiB,這 5 個程序會分別增加 100 KiB。
  • Total 是這項程序保留的所有 VMO 及其子項 VMO 的總大小,包括與其他程序共用的 VMO。

部分 VMOs 會附上名稱。您通常可以根據名稱,瞭解 VMO 的用途。例如,如果 VMO 的名稱開頭為 scudo,則 Scudo 分配器可能會使用這個名稱。這個名稱可讓 ffx profile memory 將指定程序的 VMO 分類為可能的來源。類別清單包括:

  • [scudo]:Scudo 使用的 VMO,Fchsia 的預設記憶體分配器。
  • [stacks]:用來儲存程序執行緒堆疊的 VMO。
  • [blobs]:由 blobFS 發出的 VMOs。其中可能包含已修改的子 VMOs。
  • [relro]:包含已移動二進位檔中唯讀區段的 VMO。
  • [data]:包含二進位檔資料區段的 VMO。
  • [unnamed]:沒有名稱的 VMO。

如果 VMOs 的名稱不屬於任何內建類別,系統會將其顯示為專屬類別。

基本上,ffx profile memory 指令會使用 memory_monitor 元件擷取系統中所有 VMO 的記憶體資訊。

評估一段時間內的記憶體用量

如要追蹤特定時間間隔內的記憶體用量,請執行下列指令:

ffx profile memory --interval SECONDS

SECONDS 替換成時間間隔 (以秒為單位)。

下列範例指令每 3 秒會檢查目標 Fuchsia 裝置的記憶體用量,直到指令終止為止 (通常會在終端機中按下 CTRL+C):

$ ffx profile memory --csv --interval 3

請注意,範例指令會以 CSV 格式 (--csv) 列印輸出內容。為了進行偵錯,如要取得 memory_monitor 元件匯出的原始資料,您可以使用 --debug-json 選項執行指令。