2010-02-24 10 views
9

Vorrei sapere qual è la dimensione totale dell'heap che è in uso in un determinato momento da un processo Java e devo usare jmap.Trova la dimensione heap corrente con jmap

L'uscita del jmap -heap <pid> mi dà qualcosa di simile:

 
Attaching to process ID 2899, please wait... 
Debugger attached successfully.    
Server compiler detected.     
JVM version is 14.2-b01      

using thread-local object allocation. 
Parallel GC with 2 thread(s)   

Heap Configuration: 
    MinHeapFreeRatio = 40 
    MaxHeapFreeRatio = 70 
    MaxHeapSize  = 1258291200 (1200.0MB) 
    NewSize   = 1048576 (1.0MB)  
    MaxNewSize  = 4294901760 (4095.9375MB) 
    OldSize   = 4194304 (4.0MB)   
    NewRatio   = 8      
    SurvivorRatio = 8      
    PermSize   = 16777216 (16.0MB)  
    MaxPermSize  = 67108864 (64.0MB)  

Heap Usage: 
PS Young Generation 
Eden Space:   
    capacity = 119013376 (113.5MB) 
    used  = 117277608 (111.84464263916016MB) 
    free  = 1735768 (1.6553573608398438MB) 
    98.54153536489882% used 
From Space: 
    capacity = 131072 (0.125MB) 
    used  = 81920 (0.078125MB) 
    free  = 49152 (0.046875MB) 
    62.5% used 
To Space: 
    capacity = 131072 (0.125MB) 
    used  = 0 (0.0MB) 
    free  = 131072 (0.125MB) 
    0.0% used 
PS Old Generation 
    capacity = 954466304 (910.25MB) 
    used  = 80791792 (77.04905700683594MB) 
    free  = 873674512 (833.2009429931641MB) 
    8.46460390077846% used 
PS Perm Generation 
    capacity = 57671680 (55.0MB) 
    used  = 41699008 (39.76727294921875MB) 
    free  = 15972672 (15.23272705078125MB) 
    72.30413263494319% used 

Posso usare una formula per questi valori per scoprire memoria totale utilizzata?

Altri suggerimenti su come trovarlo su Linux sono i benvenuti, ma jmap li ha preceduti.

Grazie

risposta

2

Le voci sotto Heap Usage: stanno elencando i vari pool di memoria partizionato nella JVM, insieme con la loro dimensione massima, utilizzato e lo spazio libero. Potresti semplicemente sommare i vari valori used:, che dovrebbero darti un valore ragionevole per l'utilizzo totale della memoria, sebbene possa esserci qualche overhead JVM che non è rappresentato nei pool elencati.

+0

L'esecuzione di 'jmap -heap: format = b ' e l'analisi del file di heap heap con Memory Analyzing Tool di Eclipse mi dà un utilizzo totale di 22MB. Non riesco a trovare un modo per ottenere lo stesso valore totale ... – fmoga

+0

@MelmanRo: La mia ipotesi è che lo strumento Eclipse abbia rimosso dal calcolo tutti gli oggetti non raggiungibili (cioè to-be garbage collection), che è un calcolo di quale sarebbe la dimensione dell'heap * se si eseguisse un GC sweep completo. Ritengo che l'attuale * effettivo * utilizzo della memoria del sistema operativo sia il totale dei vari pool come descritto. – skaffman

+0

Questa può essere la fonte di una così grande differenza? – fmoga

3

se si sta cercando di confrontare qualcosa come jconsole o jvisualvm con la finestra principale che mostra 'utilizzo totale dell'heap' ho scoperto che aggiungendo 'spazio eden usato' e 'spazio ps vecchio usato' ho ottenuto l'equivalente di che cosa mostra questo grafico nei programmi di cui sopra ora è