Mengapa nilai% MEM di atas tidak menambah total memori yang digunakan?


18

Saat ini saya sedang men-debug masalah kinerja dengan VPS saya dan untuk itu saya mencoba memahami proses mana yang paling banyak memakan memori. Membaca atas, inilah yang saya dapatkan:

Mem:    366544k total,   321396k used,    45148k free,      380k buffers
Swap:  1048572k total,   592388k used,   456184k free,     7756k cached

  PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND                                                                                  
12339 ruby      20   0  844m  74m 2440 S    0 20.8   0:24.84 ruby                                                                                     
12363 ruby      20   0  844m  73m 1576 S    0 20.6   0:00.26 ruby                                                                                     
21117 ruby      20   0  171m  33m 1792 S    0  9.3   2:03.98 ruby                                                                                     
11846 ruby      20   0  858m  21m 1820 S    0  6.0   0:09.15 ruby                                                                                     
21277 ruby      20   0  219m  11m 1648 S    0  3.2   2:00.98 ruby                                                                                     
  792 root      20   0  266m  10m 1024 S    0  3.0   1:40.06 ruby                                                                                     
  532 mysql     20   0  234m 4760 1040 S    0  1.3   0:41.58 mysqld                                                                                   
  793 root      20   0  250m 4616  984 S    0  1.3   1:20.55 ruby                                                                                     
  586 root      20   0  156m 4532  848 S    0  1.2   6:17.10 god                                                                                      
12315 ruby      20   0  175m 2412 1900 S    0  0.7   0:07.55 ruby                                                                                     
 3844 root      20   0 44036 2132 1028 S    0  0.6   1:08.22 ruby                                                                                     
10939 ruby      20   0  179m 1884 1724 S    0  0.5   0:08.33 ruby                                                                                     
 4660 ruby      20   0  229m 1592 1440 S    0  0.4   2:55.46 ruby                                                                                     
 3879 nobody    20   0 37428  964  520 S    0  0.3   0:01.99 nginx 

Seperti yang Anda lihat, memori saya sekitar 90% digunakan (yang merupakan masalah saya) tetapi ketika Anda menambahkan nilai-nilai% MEM, hanya sekitar 50-60% saja. Hal yang sama, RES tidak menambahkan hingga ~ 350mb. Mengapa? Apakah saya salah memahami maknanya?

Terima kasih


Saya pikir atas menyesuaikan jumlah baris yang ditunjukkan dengan ukuran tampilan, jadi semua proses mungkin tidak terlihat.
Samik

Jawaban:


6

Saya mencoba memahami proses makan mana yang paling banyak.

Itu sederhana: ruby !

ketika Anda menambahkan nilai-nilai% MEM, hanya sekitar 50-60% saja

Sebenarnya, menambahkan kolom seperti yang ditunjukkan memberi 69,2% .

  • Seperti yang telah dicatat oleh Samik, hal itu tentu saja tidak mencakup semua proses pada sistem Anda - cobalah untuk membatasi keluaran top -b -n 1untuk mendapatkan hasil lengkap dalam suatu file dan membaginya dengan kami sehingga kami dapat membantu Anda lebih baik.

  • Kernel juga membutuhkan sejumlah memori, dan beberapa jenis VPS (mis. Xen, KVM) akan menyimpan beberapa memori tambahan saat boot untuk penggunaan internal. Pastebin output dmesgjuga.

Untuk metrik yang lebih baik dan kemudahan penggunaan, saya sarankan Anda menggunakan htopInstal htop bukan atas, dengan opsi "Sembunyikan utas pengguna" diaktifkan:

masukkan deskripsi gambar di sini

Lihat juga memtop:

masukkan deskripsi gambar di sini


Inilah output teratas penuh: paste.ubuntu.com/1055673 dan dmesg: paste.ubuntu.com/1055674 Menggunakan htop memberi saya output yang berbeda! Saya melihat tiga dari proses MEM 22,4%, pada kenyataannya, banyak proses digandakan (mysqld juga, berkali-kali). Bagaimanapun, saya suka outputnya, jauh lebih bersih ... Memtop juga keren, saya bisa lebih memahami aplikasi ruby ​​mana yang paling banyak memakan memori;)
ben

0

topPerintah linux menunjukkan seluruh rammemori yang digunakan, tidak hanya untuk Anda, tetapi juga sistem. linux cachesbeberapa area dari hard disk Anda untuk mengatur komputer Anda. monitor mem lainnya disarankan untuk digunakan.

Dengan menggunakan situs kami, Anda mengakui telah membaca dan memahami Kebijakan Cookie dan Kebijakan Privasi kami.
Licensed under cc by-sa 3.0 with attribution required.