Cara Menggunakan Perintah pmap di Linux
Diterbitkan: 2022-06-25 Mencari tahu berapa banyak RAM yang digunakan proses Linux bukanlah hal yang mudah—terutama ketika memori bersama perlu dipertimbangkan. Untungnya, perintah pmap
membantu Anda memahami semuanya.
Pemetaan Memori
Pada sistem operasi modern, setiap proses tinggal di wilayah yang dialokasikan dari memori atau ruang alokasi . Batas wilayah yang dialokasikan tidak dipetakan langsung ke alamat perangkat keras fisik. Sistem operasi menciptakan ruang memori virtual untuk setiap proses dan bertindak sebagai lapisan abstraksi yang memetakan memori virtual ke memori fisik.
Kernel memelihara tabel terjemahan untuk setiap proses, dan ini diakses oleh CPU. Ketika kernel mengubah proses yang berjalan pada inti CPU tertentu, itu memperbarui tabel terjemahan yang mengikat proses dan inti CPU bersama-sama.
Manfaat Abstraksi
Ada manfaat dari skema ini. Penggunaan memori agak dienkapsulasi dan dikotak pasir untuk setiap proses di wilayah pengguna. Sebuah proses hanya "melihat" memori dalam hal alamat memori virtual. Ini berarti hanya dapat bekerja dengan memori yang telah diberikan oleh sistem operasi. Kecuali jika ia memiliki akses ke beberapa memori bersama, ia tidak mengetahui atau memiliki akses ke memori yang dialokasikan untuk proses lain.
Abstraksi dari memori fisik berbasis perangkat keras ke dalam alamat memori virtual memungkinkan kernel mengubah alamat fisik beberapa memori virtual yang dipetakan. Itu dapat menukar memori ke disk dengan mengubah alamat sebenarnya yang ditunjuk oleh wilayah memori virtual. Itu juga dapat menunda penyediaan memori fisik sampai benar-benar diperlukan.
Selama permintaan untuk membaca atau menulis memori dilayani seperti yang diminta, kernel bebas untuk mengatur tabel pemetaan sesuai keinginannya.
RAM sesuai Permintaan
Tabel pemetaan dan konsep "RAM sesuai permintaan" membuka kemungkinan memori bersama . Kernel akan mencoba untuk menghindari memuat hal yang sama ke dalam memori lebih dari sekali. Misalnya, itu akan memuat pustaka bersama ke dalam memori satu kali dan memetakannya ke berbagai proses yang perlu menggunakannya. Setiap proses akan memiliki alamat uniknya sendiri untuk pustaka bersama, tetapi semuanya akan menunjuk ke lokasi sebenarnya yang sama.
Jika wilayah memori bersama dapat ditulis, kernel menggunakan skema yang disebut copy-on-write. Jika satu proses menulis ke memori bersama dan proses lain yang berbagi memori itu tidak seharusnya melihat perubahan, salinan memori bersama dibuat pada titik permintaan tulis.
Kernel Linux 2.6.32, dirilis pada bulan Desember 2009, memberi Linux fitur yang disebut "Penggabungan Kernel SamePage." Ini berarti Linux dapat mendeteksi wilayah data yang identik di ruang alamat yang berbeda. Bayangkan serangkaian mesin virtual yang berjalan pada satu komputer, dan semua mesin virtual menjalankan sistem operasi yang sama. Menggunakan model memori bersama dan copy-on-write, overhead pada komputer host dapat dikurangi secara drastis.
Semua itu membuat penanganan memori di Linux canggih dan seoptimal mungkin. Tetapi kecanggihan itu membuat sulit untuk melihat suatu proses dan mengetahui apa sebenarnya penggunaan memorinya.
Utilitas pmap
Kernel memaparkan banyak hal yang dilakukannya dengan RAM melalui dua file semu di sistem file semu informasi sistem “/ proc”. Ada dua file per proses, dinamai untuk ID proses atau PID dari setiap proses: “/proc/maps” dan “/proc//smaps.”
Alat pmap
membaca informasi dari file-file ini dan menampilkan hasilnya di jendela terminal. Jelas bahwa kita perlu memberikan PID dari proses yang kita minati setiap kali kita menggunakan pmap
.
Menemukan ID Proses
Ada beberapa cara untuk menemukan PID dari suatu proses. Berikut kode sumber untuk program sepele yang akan kita gunakan dalam contoh kita. Itu ditulis dalam C. Yang dilakukannya hanyalah mencetak pesan ke jendela terminal dan menunggu pengguna menekan tombol "Enter".
#sertakan <stdio.h> int main(int argc, char *argv[]) { printf("Program pengujian How-To Geek."); getc(stdin); } // akhir dari main
Program dikompilasi ke executable yang disebut pm
menggunakan kompiler gcc
:
gcc -o pm pm.c
Karena program akan menunggu pengguna menekan "Enter", program akan tetap berjalan selama yang kita inginkan.
./pm
Program diluncurkan, mencetak pesan, dan menunggu penekanan tombol. Kita sekarang dapat mencari PID-nya. Perintah ps
mencantumkan proses yang sedang berjalan. Opsi -e
(tampilkan semua proses) membuat ps
mencantumkan setiap proses. Kami akan menyalurkan output melalui grep
dan menyaring entri yang memiliki "pm" di namanya.
ps -e | grep pm
Ini mencantumkan semua entri dengan "pm" di mana saja dalam nama mereka.
Kita bisa lebih spesifik menggunakan perintah pidof
. Kami memberi pidof
nama proses yang kami minati pada baris perintah, dan mencoba menemukan kecocokan. Jika kecocokan ditemukan, pidof
mencetak PID dari proses pencocokan.
pidof pm
Metode pidof
lebih rapi ketika Anda mengetahui nama prosesnya, tetapi metode ps
akan berfungsi meskipun hanya mengetahui sebagian dari nama prosesnya.
Menggunakan pmap
Dengan menjalankan program pengujian kami, dan setelah kami mengidentifikasi PID-nya, kami dapat menggunakan pmap seperti ini:
peta 40919
Pemetaan memori untuk proses terdaftar untuk kami.
Inilah output lengkap dari perintah:
40919: ./pm 000056059f06c000 4K r---- pm 000056059f06d000 4K rx-- pm 000056059f06e000 4K r---- pm 000056059f06f000 4K r---- pm 000056059f070000 4K rw --- pm 000056059fc39000 132K rw--- [ segera ] 00007f97a3edb000 8K rw--- [ segera ] 00007f97a3edd000 160K r---- libc.so.6 00007f97a3f05000 1616K rx-- libc.so.6 00007f97a4099000 352K r---- libc.so.6 00007f97a40f1000 4K ----- libc.so.6 00007f97a40f2000 16K r---- libc.so.6 00007f97a40f6000 8K rw--- libc.so.6 00007f97a40f8000 60K rw--- [ segera ] 00007f97a4116000 4K r---- ld-linux-x86-64.so.2 00007f97a4117000 160K rx-- ld-linux-x86-64.so.2 00007f97a413f000 40K r---- ld-linux-x86-64.so.2 00007f97a4149000 8K r---- ld-linux-x86-64.so.2 00007f97a414b000 8K rw--- ld-linux-x86-64.so.2 00007ffca0e7e000 132K rw --- [ tumpukan ] 00007ffca0fe1000 16K r---- [ segera ] 00007ffca0fe5000 8K rx-- [ segera ] ffffffffff600000 4K --x-- [ segera ] total 2756K
Baris pertama adalah nama proses dan PID-nya. Setiap baris lainnya menunjukkan alamat memori yang dipetakan, dan jumlah memori di alamat itu, dinyatakan dalam kilobyte. Lima karakter berikutnya dari setiap baris disebut izin memori virtual . Izin yang valid adalah:
- r : Memori yang dipetakan dapat dibaca oleh proses.
- w : Memori yang dipetakan dapat ditulis oleh proses.
- x : Proses dapat mengeksekusi instruksi apapun yang terdapat dalam memori yang dipetakan.
- s : Memori yang dipetakan dibagikan, dan perubahan yang dibuat pada memori bersama dapat dilihat oleh semua proses yang berbagi memori.
- R : Tidak ada reservasi untuk ruang swap untuk memori yang dipetakan ini.
Informasi terakhir pada setiap baris adalah nama sumber pemetaan. Ini bisa berupa nama proses, nama perpustakaan, atau nama sistem seperti tumpukan atau tumpukan.
Tampilan Diperpanjang
Opsi -x
(diperpanjang) menyediakan dua kolom tambahan.
pmap -x 40919
Kolom diberi judul. Kita telah melihat kolom “Address”, “Kbytes”, “Mode”, dan “Mapping”. Kolom baru disebut "RSS" dan "Kotor."
Berikut keluaran lengkapnya:
40919: ./pm Alamat Kbytes RSS Pemetaan Mode Kotor 000056059f06c000 4 4 0 r---- pm 000056059f06d000 4 4 0 rx-- pm 000056059f06e000 4 4 0 r---- pm 000056059f06f000 4 4 4 r---- pm 000056059f070000 4 4 4 rw --- pm 000056059fc39000 132 4 4 rw--- [ segera ] 00007f97a3edb000 8 4 4 rw--- [ segera ] 00007f97a3edd000 160 160 0 r---- libc.so.6 00007f97a3f05000 1616 788 0 rx-- libc.so.6 00007f97a4099000 352 64 0 r---- libc.so.6 00007f97a40f1000 4 0 0 ----- libc.so.6 00007f97a40f2000 16 16 16 r---- libc.so.6 00007f97a40f6000 8 8 8 rw--- libc.so.6 00007f97a40f8000 60 28 28 rw--- [ segera ] 00007f97a4116000 4 4 0 r---- ld-linux-x86-64.so.2 00007f97a4117000 160 160 0 rx-- ld-linux-x86-64.so.2 00007f97a413f000 40 40 0 r---- ld-linux-x86-64.so.2 00007f97a4149000 8 8 8 r---- ld-linux-x86-64.so.2 00007f97a414b000 8 8 8 rw--- ld-linux-x86-64.so.2 00007ffca0e7e000 132 12 12 rw--- [ tumpukan ] 00007ffca0fe1000 16 0 0 r---- [ segera ] 00007ffca0fe5000 8 4 0 rx-- [ segera ] ffffffffff600000 4 0 0 --x-- [ segera ] ---------------- ------- ------- ------- jumlah kB 2756 1328 96
- RSS : Ini adalah ukuran set penduduk . Artinya, jumlah memori yang saat ini ada di RAM, dan tidak tertukar.
- Kotor : Memori “Kotor” telah diubah sejak proses—dan pemetaan—dimulai.
Tunjukkan Semuanya
The -X
(bahkan lebih dari diperpanjang) menambahkan kolom tambahan ke output. Perhatikan huruf besar "X." Opsi lain yang disebut -XX
(bahkan lebih dari -X
) menunjukkan kepada Anda semua yang dapat pmap
dari kernel. Karena -X
adalah subset dari -XX
, kami akan menjelaskan output dari -XX
.
pmap -XX 40919
Outputnya membungkus dengan mengerikan di jendela terminal dan praktis tidak dapat dipahami. Berikut adalah keluaran lengkapnya:
40919: ./pm Address Perm Offset Device Ukuran Inode KernelPageSize MMUPageSize Rss Pss Shared_Clean Shared_Dirty Private_Clean Private_Dirty Referensi Anonim MalasFree AnonHugePages ShmemPmdMapped FilePmdMapped Shared_Hugetlb Private_Hugetlb Swap SwapPss Locked lag 56059f06c000 r--p 00000000 08:03 393304 4 4 4 4 0 0 4 0 4 0 0 0 0 0 0 0 0 0 0 rd mr mw me dw sd pm 56059f06d000 r-xp 00001000 08:03 393304 4 4 4 4 0 0 4 0 4 0 0 0 0 0 0 0 0 0 0 mantan mr mw saya dw sd pm 56059f06e000 r--p 00002000 08:03 393304 4 4 4 4 0 0 4 0 4 0 0 0 0 0 0 0 0 0 0 rd mr mw me dw sd pm 56059f06f000 r--p 00002000 08:03 393304 4 4 4 4 0 0 0 4 4 4 0 0 0 0 0 0 0 0 0 rd mr mw me dw ac sd pm 56059f070000 rw-p 00003000 08:03 393304 4 4 4 4 4 0 0 0 4 4 4 0 0 0 0 0 0 0 0 0 0 rd wr mr mw me dw ac sd pm 56059fc39000 rw-p 00000000 00:00 0 132 4 4 4 4 0 0 0 4 4 4 0 0 0 0 0 0 0 0 0 rd wr mr mw me ac sd [heap] 7f97a3edb000 rw-p 00000000 00:00 0 8 4 4 4 4 0 0 0 4 4 4 0 0 0 0 0 0 0 0 0 rd wr mr mw me ac sd 7f97a3edd000 r--p 00000000 08:03 264328 160 4 4 160 4 160 0 0 0 160 0 0 0 0 0 0 0 0 0 0 rd mr mw me sd libc.so.6 7f97a3f05000 r-xp 00028000 08:03 264328 1616 4 4 788 32 788 0 0 0 788 0 0 0 0 0 0 0 0 0 0 mantan mr mw me sd libc.so.6 7f97a4099000 r--p 001bc000 08:03 264328 352 4 4 64 1 64 0 0 0 64 0 0 0 0 0 0 0 0 0 0 rd mr mw me sd libc.so.6 7f97a40f1000 ---p 00214000 08:03 264328 4 4 4 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 mr mw me sd libc.so.6 7f97a40f2000 r--p 00214000 08:03 264328 16 4 4 16 16 0 0 0 16 16 16 0 0 0 0 0 0 0 0 0 rd mr mw me ac sd libc.so.6 7f97a40f6000 rw-p 00218000 08:03 264328 8 4 4 8 8 0 0 0 8 8 8 0 0 0 0 0 0 0 0 0 rd wr mr mw me ac sd libc.so.6 7f97a40f8000 rw-p 00000000 00:00 0 60 4 4 28 28 0 0 0 28 28 28 0 0 0 0 0 0 0 0 0 rd wr mr mw me ac sd 7f97a4116000 r--p 00000000 08:03 264305 4 4 4 4 0 4 0 0 0 4 0 0 0 0 0 0 0 0 0 0 rd mr mw me dw sd ld-linux-x86-64.so.2 7f97a4117000 r-xp 00001000 08:03 264305 160 4 4 160 11 160 0 0 0 160 0 0 0 0 0 0 0 0 0 0 mantan mr mw me dw sd ld-linux-x86-64.so.2 7f97a413f000 r--p 00029000 08:03 264305 40 4 4 40 1 40 0 0 0 40 0 0 0 0 0 0 0 0 0 0 rd mr mw me dw sd ld-linux-x86-64.so.2 7f97a4149000 r--p 00032000 08:03 264305 8 4 4 8 8 0 0 0 8 8 8 0 0 0 0 0 0 0 0 0 rd mr mw me dw ac sd ld-linux-x86-64.so.2 7f97a414b000 rw-p 00034000 08:03 264305 8 4 4 8 8 0 0 0 8 8 8 0 0 0 0 0 0 0 0 0 rd wr mr mw saya dw ac sd ld-linux-x86-64.so.2 7ffca0e7e000 rw-p 00000000 00:00 0 132 4 4 12 12 0 0 0 12 12 12 0 0 0 0 0 0 0 0 0 0 rd wr mr mw me gd ac [stack] 7ffca0fe1000 r--p 00000000 00:00 0 16 4 4 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 rd mr pf io de dd sd [vvar] 7ffca0fe5000 r-xp 00000000 00:00 0 8 4 4 4 0 4 0 0 0 4 0 0 0 0 0 0 0 0 0 0 mantan mr mw me de sd [vdso] ffffffffff600000 --xp 00000000 00:00 0 4 4 4 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ex [vsyscall] ==== ============== =========== ==== === ================ ========== ============= ========================= ==== ===== ======== ======================================= === ============== =============== ==== ======= ====== = ========== 2756 92 92 1328 157 1220 0 12 96 1328 96 0 0 0 0 0 0 0 0 0 0 KB
Ada banyak informasi di sini. Inilah yang dipegang kolom:
- Alamat : Alamat awal pemetaan ini. Ini menggunakan pengalamatan memori virtual.
- Perm : Izin memori.
- Offset : Jika memori berbasis file, offset pemetaan ini di dalam file.
- Perangkat : Nomor perangkat Linux, diberikan dalam nomor mayor dan minor. Anda dapat melihat nomor perangkat di komputer Anda dengan menjalankan perintah
lsblk
. - Inode : Inode dari file yang terkait dengan pemetaan. Misalnya, dalam contoh kita, ini bisa menjadi inode yang menyimpan informasi tentang program pm.
- Ukuran : Ukuran wilayah yang dipetakan memori.
- KernelPageSize : Ukuran halaman yang digunakan oleh kernel.
- MMUPageSize : Ukuran halaman yang digunakan oleh unit manajemen memori.
- Rss : Ini adalah ukuran set penduduk . Artinya, jumlah memori yang saat ini ada di RAM, dan tidak tertukar.
- Pss : Ini adalah ukuran saham yang proporsional . Ini adalah ukuran bersama pribadi yang ditambahkan ke (ukuran bersama dibagi dengan jumlah pembagian.)
- Shared_Clean : Jumlah memori yang dibagikan dengan proses lain yang belum diubah sejak pemetaan dibuat. Perhatikan bahwa meskipun memori dapat dibagikan, jika belum benar-benar dibagikan, itu masih dianggap sebagai memori pribadi.
- Shared_Dirty : Jumlah memori yang dibagikan dengan proses lain yang telah diubah sejak pemetaan dibuat.
- Private_Clean : Jumlah memori pribadi—tidak dibagikan dengan proses lain—yang belum diubah sejak pemetaan dibuat.
- Private_Dirty : Jumlah memori pribadi yang telah diubah sejak pemetaan dibuat.
- Referensi : Jumlah memori yang saat ini ditandai sebagai referensi atau diakses.
- Anonim : Memori yang tidak memiliki perangkat untuk ditukar. Artinya, itu tidak didukung file.
- LazyFree : Halaman yang telah ditandai sebagai
MADV_FREE
. Halaman-halaman ini telah ditandai sebagai tersedia untuk dibebaskan dan diklaim kembali, meskipun mungkin ada perubahan tidak tertulis di dalamnya. Namun, jika perubahan berikutnya terjadi setelahMADV_FREE
telah ditetapkan pada pemetaan memori, benderaMADV_FREE
akan dihapus dan halaman tidak akan diambil kembali sampai perubahan tersebut ditulis. - AnonHugePages : Ini adalah halaman memori "besar" yang didukung non-file (lebih besar dari 4 KB).
- ShmemPmdMapped : Memori bersama yang terkait dengan halaman besar. Mereka juga dapat digunakan oleh sistem file yang berada sepenuhnya di memori.
- FilePmdMapped : Direktori Page Middle adalah salah satu skema paging yang tersedia untuk kernel. Ini adalah jumlah halaman yang didukung file yang ditunjukkan oleh entri PMD.
- Shared_Hugetlb : Translation Lookaside Tables, atau TLBs, adalah cache memori yang digunakan untuk mengoptimalkan waktu yang dibutuhkan untuk mengakses lokasi memori ruang pengguna. Angka ini adalah jumlah RAM yang digunakan dalam TLB yang terkait dengan halaman memori besar bersama.
- Private_Hugetlb : Angka ini adalah jumlah RAM yang digunakan dalam TLB yang terkait dengan halaman memori pribadi yang besar.
- Swap : Jumlah swap yang digunakan.
- SwapPss : Ukuran share proporsional swap . Ini adalah jumlah swap yang terdiri dari halaman memori pribadi yang ditukar yang ditambahkan ke (ukuran bersama dibagi dengan jumlah bagian.)
- Terkunci : Pemetaan memori dapat dikunci untuk mencegah sistem operasi mengeluarkan memori heap atau off-heap.
- THPeligible : Ini adalah tanda yang menunjukkan apakah pemetaan memenuhi syarat untuk mengalokasikan halaman besar yang transparan . 1 berarti benar, 0 berarti salah. Halaman besar transparan adalah sistem manajemen memori yang mengurangi overhead pencarian halaman TLB pada komputer dengan jumlah RAM yang besar.
- VmFlags : Lihat daftar flag di bawah ini.
- Pemetaan : Nama sumber pemetaan. Ini bisa berupa nama proses, nama perpustakaan, atau nama sistem seperti tumpukan atau tumpukan.
VmFlags—tanda memori virtual—akan menjadi bagian dari daftar berikut.
- rd : Dapat dibaca.
- wr : Dapat ditulisi.
- mis : Dapat dieksekusi.
- sh : Dibagikan.
- mr : boleh membaca.
- mw : Boleh menulis.
- saya : Boleh eksekusi.
- ms : Boleh berbagi.
- gd : Segmen tumpukan tumbuh ke bawah.
- pf : Rentang nomor bingkai halaman murni. Nomor bingkai halaman adalah daftar halaman memori fisik.
- dw : Dinonaktifkan menulis ke file yang dipetakan.
- lo : Halaman terkunci di memori.
- io : Area I/O yang dipetakan memori.
- sr : Saran membaca berurutan disediakan (oleh fungsi
madvise()
.) - rr : Saran membaca acak disediakan.
- dc : Jangan menyalin wilayah memori ini jika prosesnya bercabang.
- de : Jangan memperluas wilayah memori ini pada pemetaan ulang.
- ac : Daerah dapat dipertanggungjawabkan.
- nr : Ruang swap tidak disediakan untuk area tersebut.
- ht : Area menggunakan halaman TLB besar.
- sf : Kesalahan halaman sinkron.
- ar : Bendera khusus arsitektur.
- wf : Hapus wilayah memori ini jika prosesnya bercabang.
- dd : Jangan sertakan wilayah memori ini dalam dump inti.
- sd : Bendera kotor yang lembut.
- mm : Area peta campuran.
- hg : Bendera saran halaman besar.
- nh : Tidak ada bendera saran halaman besar.
- mg : Bendera saran yang dapat digabung.
- bt : halaman penjagaan ketidakstabilan suhu bias ARM64.
- mt : Tag ekstensi penandaan memori ARM64 diaktifkan.
- um : Userfaultfd tidak ada pelacakan.
- uw : Userfaultfd wr-protect pelacakan.
Manajemen Memori Rumit
Dan bekerja mundur dari tabel data untuk memahami apa yang sebenarnya terjadi itu sulit. Tapi setidaknya pmap
memberi Anda gambaran lengkap sehingga Anda memiliki kesempatan terbaik untuk mencari tahu apa yang perlu Anda ketahui.
Sangat menarik untuk dicatat bahwa program contoh kami dikompilasi ke biner 16 KB yang dapat dieksekusi, namun menggunakan (atau berbagi) beberapa 2756 KB memori, hampir seluruhnya karena perpustakaan runtime.
Satu trik terakhir yang rapi adalah Anda dapat menggunakan pmap
dan pidof
bersama-sama, menggabungkan tindakan menemukan PID dari proses dan meneruskannya ke pmap
menjadi satu perintah:
pmap $(pidof pm)