Wie hoch ist der Grundspeicherbedarf einer JVM?

Status
Nicht offen für weitere Antworten.

lacarpe

Mitglied
Hallo zusammen,

ich lasse ein Java-Programm unter Linux (Debian) mit der Sun-1.5-VM und den Parametern -Xms20m -Xmx20m laufen. Wenn ich mir jetzt den Speicherbedarf des Prozesses ausgebe erhalte ich ca. 200MB. Mache ich dasselbe mit -Xms60m -Xmx60m erhalte ich 240MB.

Daraus schließe ich, dass die JVM alleine schon 180MB benötigt, also den Heap noch nicht mitgerechnet. Kann das sein? Das finde ich unglaublich viel. Ist das normal für eine JVM? Kann ich das irgendwie drosseln? Sind andere JVMs (also nicht die von Java) besser was den Grundspeicherbeadrf angeht?

Ich bin mir auch nicht zu 100% sicher, ob ich das mit den 180MB Grundspeicherbedarf richtig deute. Irgendwo habe ich gelesen, dass ein Javaprogramm mit 60MB Speicherverbrauch (JVM + Heap) betrieben wurde. Kann das sein?

Ich bin verwirrt....

Herzlichen Dank schon mal,
lacarpe
 

Wildcard

Top Contributor
Nein, das ist viel zu viel. Das kann gar nicht sein. Ich müsste jetzt nachsehen, die VM dürfte in aktueller Version aber irgendwo bei 30MB liegen.
 

lacarpe

Mitglied
Woran kann es denn liegen, dass es bei mir 240MB (180 VM + 60 Heap) sind? Vielleicht muss ich noch sagen, die 240MB Arbeitsspeicherverbrauch teilt sich auf auf in
- 40MB physikalischer Speicher belegt
- 200 MB virtueller Speicher
(Aber in welchen Anteilen physikalischer und virtueller Speicher belegt wird ist ja Sache des Betriebssystems.)

Wildcard, beziehen sich deine 30MB auf die Belegung von physikalischem Speicher? Und wären dann die 200MB belegter virtueller Speicher normal?

Wo kann ich solche Fragen nachlesen?
 
S

SlaterB

Gast
wie zählen denn selbst die 30 MB?
wenn man ein kleines Hello-World-Programm startet liegt man unter Windows doch deutlich einstellig
 

lacarpe

Mitglied
Nur zur Info wie ich die Werte ermittle (wie gesagt: Linux):
Code:
jens@pc:~/main/java/autotrader$ ps -Ao rss,vsz,command | grep TEST
ergibt:
Code:
 40856 204348 java -Xms60m -Xmx60m -classpath .....
also 40 MB physikalisch, 204 MB virtuell

@Wildcard: Würdest du die Ausgabe genauso interpretieren wie ich ?

Das mit HelloWorld würde ich gerne mal ausprobieren. Nur ist das Programm ja schnell beendet (jedenfalls nehme ich an dass die JVM unmittelbar nach Ausgabe abschaltet, richtig?). Wie messe ich da den Speicherbedarf?
 

lacarpe

Mitglied
Oder mal allgemein gefragt: Ist die Größe des von der JVM belegten Speichers abhängig vom Programm? Könnte es sein, dass die VM für ein HelloWorld-Programm ergeblich weniger Speicher für sich selbst beansprucht, als bei einer aufwändigeren Swing-basierten GUI-Applikation? Kann ich mir eigentlich nicht vorstellen. Ich denke eher so: JVM konstant (egal was damit betrieben wird) + Heap (der wiederum abhängig vom Programm).


(Bin mal eben weg, meine Tochter vom Kindergarten abholen.)
 

lacarpe

Mitglied
Wildcard hat gesagt.:
Der Speicherbedarf des Prozesses ist VM + Applikation. Trennen kannst du das nicht.
Das ist mir klar. Nur, wenn ich den Heap auf 60MB (-Xms60m -Xmx60m) begrenze, müssen die restlichen 180MB ja für was anderes sein. Da denke ich doch mal, das ist die VM, oder irre ich?
 

byte

Top Contributor
Ich denke, es hängt einfach auch stark davon ab, welche teile der Java-Klassenbibliothek verwendet werden. Die wird ja nicht perse vollständig geladen sondern immer nur die Teile, die auch wirklich referenziert werden. Insofern kann der Speicherverbrauch grade bei Swing-Geschichten schnell steigen, denn da hängen ja häufig haufenweise Objekte/ Klassen dran.

Wobei ich 240 MB schon arg viel finde. Soviel nimmt doch nicht mal Eclipse ein, wenn mich nicht alles täuscht. ;)
 

Wildcard

Top Contributor
Die VM nimmt nicht mehr als ich sag jetzt mal 20MB in Anspruch.
Ich denke da stimmt was mit den Daten nicht.
 

byte

Top Contributor
40 MB physikalisch, 204 MB virtuell

Kenn mich da nicht so aus, aber virtueller Speicher ist doch prinzipiell wurscht. Würde mich nicht wundern, wenn der gar nicht belegt ist sondern einfach nur vom System zugewiesen wird. Und die 40 MB physikalisch klingt ja normal.
 

lacarpe

Mitglied
So, dieses Programm habe ich jetzt erstellt und ausprobiert:

Code:
class Main{

    public static void main(String args[]) {
    	try{
    		Thread.sleep(10000);
    	}catch(Exception e){}
    }
}

compiliert und gestartet mit

Code:
java Main

Speicherverbrauch:
7308 -> 7MB physikalischer RAM
208308 -> 208MB virtuelles RAM

So, da ihr alle sagt, dass das nicht sein kann, versuche ich nun mal nachzuforschen, ob die Speicherangabe über ps nicht stimmt.
 

lacarpe

Mitglied
byto hat gesagt.:
Kenn mich da nicht so aus, aber virtueller Speicher ist doch prinzipiell wurscht. Würde mich nicht wundern, wenn der gar nicht belegt ist sondern einfach nur vom System zugewiesen wird. Und die 40 MB physikalisch klingt ja normal.
In meinem Fall ist es nicht wurscht, da ich einen kleinen V-Server mit 256MB RAM (physikalisch+virtuell) gemietet habe. Meine 2 Java-Programme dürfen also nicht zuviel Speicher "verschwenden". Aber ich habe allmählich auch das Gefühl, dass die 200MB virtueller Speicher nicht stimmen. Es wird ja auch zwischem aktiven und passivem Speicher unterschieden. Möglicherweise sind 200MB für das Javaprogramm allokiert, werden aber nicht genutzt. Dann stellt sich für mich die Frage, warum da so viel virtueller Speicher zugewiesen, aber nicht genutzt wird. Mag sein, dass ich hier auch Blödsinn rede.

Letztlich will ich nur wissen, ob ich 2 Javaprogramme auf 256MB laufen lassen kann, wobei in den 256MB der swap schon drin ist. Leider kann ich das über ps oder top anscheinend nicht rausfinden. Oder ich verstehe die gelieferten Angaben bzw. die Speicherverwaltung insgesamt nicht. :bahnhof: :?: :?:
 

lacarpe

Mitglied
Ich bin's noch mal,

also ich habe nun versucht das kleine Javapgrogramm (s.o.) im V-Server mehrfach zu starten:

1.
Vor dem Start sind ca. 50 MB Arbeitsspeicher (physikalisch + virtuell) belegt.
2.
Dann starte ich das kleine Programm Main mit -Xmx10m. Wie schon gesagt werden dann 200MB Arbeitspeicher (physikalisch + virtuell) als belegt angezeigt.
3.
Nun kann ich das Programm Main nicht noch ein zweites Mal (parallel zum ersten) starten und ich erhalte eine Meldung
"Could not reserve enough space for object heap. Could not create the Java virtual machine."

Folglich: Anscheinend lastet das Mini-Programm den zur Verfügung stehenden Arbeitsspeicher voll aus.

Ich glaub's nicht. :roll:
 

Wildcard

Top Contributor
Vielleicht ein Bug?
Hast du die SUN VM drauf?
Meine 11,3 MB (für ein Fenster inkl. VM) waren der gesamt Speicher da überhaupt kein Swap verwendet wurde.
Da stimmt in jedem Fall was nicht, normal ist das nicht.
 

lacarpe

Mitglied
Ich habe das jetzt noch einmal auf meinem ubuntu-System getetstet.

Mein Ubuntu benötigt nach dem Start 160MB (swap=0) und nach Start der beiden Japa-Applikationen 273MB (swap=0) also pro Applikation gut 50MB. Das entspricht ja auch euren Angaben.

Der Wert "virtueller Speicher" scheint wenig aussagekräftig zu sein. Dazu habe ich ein paar Infos erhalten: http://forum.ubuntuusers.de/topic/83509

So und nun glaube ich, dass es an der Konfiguration meines v-Servers liegt. Wen es interessiert, er ist so eingestellt:
vmguarpages: ca. 100 MB (memory-guarantee)
oomguarpages: ca. 100 MB (out-of-memory-guarantee)
privvmpages: ca. 256 MB (max memory)

Der Hoster bewirbt das Paket mit 256MB Arbeitsspeicher. Und 256MB hat er auch eingestellt. allerdings nur bei privvmpages. Dieser wert sagt nur, dass ich maximal(!) 256MB nutzen kann. Garantiert sind mir in Wahrheit aber nur 100MB (vmguarpages-Wert). Alles dadrüber hängt von der Auslastung des Gesamtservers ab. Prozesse, die über 100MB Arbeitsspeicher hinausweisen sind also unsicher, müssen nicht zur Ausführung kommen. Das ist natürlich Quark.

Und daran könnte es natürlich liegen. Mein Debian liegt bei 50MB, ein Javaprogramm ebenfalls. Da ist dann für das 2. Programm ggf. kein Platz mehr. Ja, toll!

Mein Hoster will mir zwar weiß machen, dass dennoch 256MB bereit stehen, da das Gesamt-System nicht ausgelastet ist:
Es bringt daher nichts, den Wert für vmguarpages zu erhöhen, da das System
über genügend Resourcen verfügt. Vielmehr wird es an dem Overheap-Speicher,
der beim Start von Java in Anspruch genommen möchte, liegen.
Overheap-Speicher? Stimmt das? Und genau dazu mache ich einen zweiten Thread auf (ist ja eine andere Frage).

Jedenfalls vielen Dank für euer Mitdenken.
 

lacarpe

Mitglied
Wildcard hat gesagt.:
100MB Speicher?
Das ist echt mal ein Witz :lol:
Ja, wenn's nicht so traurig wäre :roll:

Er sagt zwar das System ist nicht ausgelastet und somit hätte ich 256MB, aber dann könnte er ja den entsprechenden Wert auf 256MB anheben, so dass es mir garantiert ist. Ich werde mal nachfragen, bezweifle aber, dass er es tun wird. Wenn nicht, mache ich vom 10-tägigen Kündigungsrecht Gebrauch. Basta.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
berserkerdq2 Ein Gamepanel sei in 60x60 Pixel Quadrate aufgeteilt und isgesamt 600 Pixel breit & 300 Pixel hoch. Wie auf Quadrate zugreifen? Allgemeine Java-Themen 5
C Mehrere Seiten drucken in Hoch- und Querformat Allgemeine Java-Themen 0
S Projektumfang zu hoch? Allgemeine Java-Themen 6
F Welche Systeme für hoch skalierbare Webanwendung? Allgemeine Java-Themen 7
B Mausbewegung im Thread erkennen (hoch/runter) Allgemeine Java-Themen 6
O Speicherverbrauch von Java / VM sehr hoch? Allgemeine Java-Themen 27
N 2 hoch 100 berechnen Allgemeine Java-Themen 8
M Problem mit dem Lesen einer projektinternen .csv aus der runnable JAR Allgemeine Java-Themen 3
P Verschiedene Aspekte einer idempotent API verstehen? Allgemeine Java-Themen 16
Zrebna Ausführung einer Testmethode in der IDE erfolgreich - failt aber via 'mvn test' Allgemeine Java-Themen 5
S Interpreter-Fehler Kann mir das mal einer erklären? Allgemeine Java-Themen 12
Zrebna Aus einer jar-Datei eine exe-Datei erzeugen lassen Allgemeine Java-Themen 37
O Text aus einer Textdatei rausholen, der zwischen zwei Schlüsselworten steht Allgemeine Java-Themen 4
V Umgang mit fehlenden Daten in einer Java-Datenanalyseanwendung Allgemeine Java-Themen 5
M Methodenübersicht einer Klasse einsehen Allgemeine Java-Themen 14
T JNA, Aufruf der Funktionen einer dll Allgemeine Java-Themen 5
I Vom Monolith zu Services in einer Webseite Allgemeine Java-Themen 1
W Variable Initialisierung mit dem Ergebnis einer Regex Allgemeine Java-Themen 1
O Werte einer Generic LinkedList zusammenrechenen Allgemeine Java-Themen 14
C Sortieren und Selektieren einer ArrayList<Point3D> Allgemeine Java-Themen 6
A Einzelne Objekte und Unterobjekte einer ArrayList ausgeben Allgemeine Java-Themen 53
TheSepp Wie kann man Leerzeichen aus einer Array liste entfernen? Allgemeine Java-Themen 10
B Ein Objekt einer Klasse mehreren anderen Klassen zur Verfügung stellen? Allgemeine Java-Themen 6
M Optimierung einer Methode (byte-Geraffel) Allgemeine Java-Themen 2
I Wie kann ich den Wert aus einer If abfrage ausgeben Allgemeine Java-Themen 23
S HTML einer Webseite 1:1 so bekommen wie es auch der Browser anzeigt? Allgemeine Java-Themen 14
melaniemueller Einzelne Zeile aus einer txt Datei in einem String speichern Allgemeine Java-Themen 12
L Java überprüfen lassen, ob sich ein gegebener Pfad / das Programm an sich auf einer CD oder Festplatte befindet Allgemeine Java-Themen 14
J (Geplante) Änderungen an einer Datei vorübergehend speichern und anwenden? Allgemeine Java-Themen 12
ME2002 Fragen aus einer Java Klausur Allgemeine Java-Themen 67
G Obfuscate einer .jar-Datei mit ProGuard? Allgemeine Java-Themen 2
G Verknüpfung einer .jar-Datei (liegt z. B. auf dem Desktop) im Autostart-Ordner erstellen? Allgemeine Java-Themen 20
C Parsen einer sich updatenden Html mithilfe von jsoup Allgemeine Java-Themen 4
E Eine Methode einer extendeten Klasse deakitivieren Allgemeine Java-Themen 12
H Performance einer Monte-Carlo-Simulation verbessern Allgemeine Java-Themen 6
LimDul Kam eine java.net.URL zu einer HashMap und ging als DNS Anfrage wieder heraus Allgemeine Java-Themen 18
E Variablen Nach Übergabe einer Variable den Constructor aufrufen Allgemeine Java-Themen 16
Zeppi NullPointerException in einer if-Abfrage Allgemeine Java-Themen 6
G Abbruch einer ViewScoped Bean in Arbeit Allgemeine Java-Themen 2
Lukas2904 Schleife mit ansteuerung einer Klasse Allgemeine Java-Themen 5
d.lumpi Aus Einer Klasse auf ein Objekt einer anderen Klasse Zugreifen Allgemeine Java-Themen 1
Lukas2904 Wie kann man cps (ClicksPerSecond) in einer GUI anzeigen lassen? Allgemeine Java-Themen 4
O Produziert das Tool "jpackage" (ab JDK 14) .exe Dateien, die auf einer Zielumgebung ohne JRE lauffähig sind ?` Allgemeine Java-Themen 7
R Lambda Expression in einer Methode execute() aufrufen (execute() ist eine Methode aus dem funktionalen Interface Command) Allgemeine Java-Themen 5
Drachenbauer wie kann ich alle instanzen einer Klasse durchsehen, ohne, dass diese in einer Liste erzeugt wurden? Allgemeine Java-Themen 11
N BlueJ Implementation einer Analoguhr Allgemeine Java-Themen 0
O Formatierte String ausgabe bei vier Variablen in einer Zeile Allgemeine Java-Themen 1
N Speicherort einer Datei im Explorer ändern Allgemeine Java-Themen 8
O Datentypen Wie kann ich den Typ einer ArrayList abfragen ? Allgemeine Java-Themen 7
O Leerzeichen und Umlaute im Pfad einer Java Applikation machen Probleme Allgemeine Java-Themen 13
H Mehrere PNG-Files in einer Datei Allgemeine Java-Themen 9
G Java Editor Löschen doppelter Zahlen einer Liste Allgemeine Java-Themen 2
J JSON Daten von einer Webseite erhalten Allgemeine Java-Themen 2
L RegEx für Teile einer Berechnung Allgemeine Java-Themen 14
L Erste Schritte TDD testen einer Methode mit injezierten Services? Allgemeine Java-Themen 12
J Zerlegen einer Zahl Allgemeine Java-Themen 6
Zrebna Wie kann man endgültig aus einer Rekursion ausbrechen? Allgemeine Java-Themen 14
MiMa Person in einer Arraylist hinzugügen mit Prüfung ? Allgemeine Java-Themen 6
Meeresgott Effizientester Weg um nach der Value einer verschachtelten Map aufzulösen Allgemeine Java-Themen 5
H Mehrere Datentypen in einer Arraylist speichern Allgemeine Java-Themen 9
MiMa Prüfziffer einer EAN Nummer berechnen Allgemeine Java-Themen 4
MiMa Erstellungsdatum einer Datei Allgemeine Java-Themen 10
Drachenbauer Wie kann ich einer existierenden Enum von außerhalb veränderte Werte zuweisen? Allgemeine Java-Themen 5
S HTML den ich von einer URL hole nicht identisch mit dem HTML im Browser Allgemeine Java-Themen 1
S Rückgabe einer HttpURLConnection für eine Seite einlesen bei der man eingeloggt ist..? Allgemeine Java-Themen 5
O Java-Applikation tut in Netbeans, als JAR nicht, wegen Pfadangaben einer benötigten Datei Allgemeine Java-Themen 8
M Hilfe bei einer Java Programmieraufgabe! Ab morgen Montag um 08:00 Uhr Allgemeine Java-Themen 5
J Algorithmen Analyse einer Schleife Allgemeine Java-Themen 6
Drachenbauer Wie finde ich den Aufrufer zu einer Methode, die sich nicht in meinem Projekt befindet? Allgemeine Java-Themen 2
J Die Letzte Zahl aus einer Text datei lesen Allgemeine Java-Themen 8
P einen public <Optinal String> in einer anderen Klasse mit einem Int vergleichen Allgemeine Java-Themen 2
A Mithilfe von einer Nummer einen Namen finden n-Beziehung Allgemeine Java-Themen 8
Scream_ilias Auf einer Website die anmeldedaten eingeben Allgemeine Java-Themen 9
V Threads Probleme beim Aufrufen von Methoden einer anderen Klasse (Threads) Allgemeine Java-Themen 14
I Lohnt sich heutzutage der Aufwand einer Portierung für MacOS Allgemeine Java-Themen 8
J Suchen von einer Scannereingabe in einem HashSet Allgemeine Java-Themen 1
M Konstruktor einer Methode Allgemeine Java-Themen 35
L Echtzeitdaten aus einer Webseite ziehen mit Java Allgemeine Java-Themen 19
V EMail, Attachments auslesen von einer Email Allgemeine Java-Themen 0
T Google Links in einer Liste Allgemeine Java-Themen 4
T Sinn einer toString Methode Allgemeine Java-Themen 3
P Durchlaufen einer Queue Allgemeine Java-Themen 9
J Größe einer CD ermitteln Allgemeine Java-Themen 10
L Operatoren Java Reflections: Alle Methoden einer Klasse aufrufen ohne Exceptions Allgemeine Java-Themen 5
H Länge einer verketteten Liste Allgemeine Java-Themen 4
B Quellcode einer Java libary finden um zu copy & paste'n Allgemeine Java-Themen 5
N Daten einer JCoTable in JTextArea anzeigen Allgemeine Java-Themen 7
sascha-sphw Java 9 module Zugriff auf eine resource einer anderen JAR Allgemeine Java-Themen 0
N Generic Type einer Generischen Klasse während der Laufzeit bekommen Allgemeine Java-Themen 2
E Erstellen einer Liste mit einer maximalen Menge an Elementen Allgemeine Java-Themen 13
M Wie kann ich ein int[] Array in einer Methode benutzen? Allgemeine Java-Themen 6
T Compiler-Fehler NoClassDefFoundError beim Laden einer Class Allgemeine Java-Themen 11
H Klassen LibGDX - Verschiedene Klassen als Value in einer Map Allgemeine Java-Themen 8
P Element einer Liste wurde hinzugefügt, aber es gibt keinen Zugriff Allgemeine Java-Themen 2
E Elemente innerhalb einer ArrayList vergleichen Allgemeine Java-Themen 33
J Einen Thread in einer Schleife Allgemeine Java-Themen 2
temi Java Programm aus einer DB laden und starten Allgemeine Java-Themen 2
J int Werte in einer anderen Klasse in Arrays speichern Allgemeine Java-Themen 3
S Hilfe bei dem Auslesen einer YAML Datei Allgemeine Java-Themen 8
D Warum kann ich eine (deflaut) Klasse aus einer Libary in einem anderen Projekt benutzen? Allgemeine Java-Themen 3

Ähnliche Java Themen

Neue Themen


Oben