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
選項執行指令。