JVM Startparameter für PermGen

Status
Nicht offen für weitere Antworten.

oltoko

Mitglied
Hallo,

ich versuche gerade, da ich öfter Probleme mit dem PermGen habe, diesen beim Start des Geronimo Servers gleich auf 256, oder sogar 512 MB zu setzen. Leider musste ich jetzt feststellen, dass die JVM mit der Option MaxPermSize anscheinend nichts anfangen kann. Beim Ausführen von

Code:
java -XX:MaxPermSize=512m -jar "C:\geronimo-tomcat6-javaee5-2.1.3\lib\boot\gshell-bootstrap.jar"

bekomme ich den Fehler: "Unrecognized VM option '' Could not create...". Was ich nicht ganz verstehe, da dieser Startparameter auch auf der Sun-Seite für VM Optionen angegeben wird. Mache ich bei meinem Aufruf etwas falsch??

Ich habs probiert mit der jre & jdk jeweils Version 1.6.0_04

Mfg
Olli
 

Wildcard

Top Contributor
Update 10 ist ja schon mehr ein major als ein minor Release. Versuch mal mit einer älteren Version, eventuell ist der Parameter entfernt worden.
 

oltoko

Mitglied
In der Doku die ich angegeben habe, steht aber auch beim Parameter dabei ...5.0 and newer....
Jedoch ist da von einer Java HotSpot VM die rede... Wenn ich ehrlich bin hab ich keine Ahnung was das sein soll :D!! Eigentlich bin ich davon ausgegangen, da in diversen Foren mein Problem schon öfters im Ähnlichen Kontext behandelt wurde, dass dies mit der "nomalen" JVM ohne weiteres Funktionieren würde. Da ja auch der Geronimo nach seinem Start von dem 65 MB verfügbaren PermGenSpace schon 50 MB benutzt sollte man auch meinen das mehr Menschen Probleme haben wenn sie auf JavaScript (Ajax) basierte Web-Projekte in einem Geronimo Server laufen lassen. Weil wenn wir ehrlich sind, wem langen schon 15 MB in einem WebServer?
 

Wildcard

Top Contributor
oltoko hat gesagt.:
Weil wenn wir ehrlich sind, wem langen schon 15 MB in einem WebServer?
Es geht ja nicht um den Heap, sondern den Perm Space.
Hast du es nun mit einer älteren Version versucht? Diese inoffiziellen Parameter kommen und gehen wie es sun beliebt.
 
M

maki

Gast
Was ist mit

-XX:permSize=512m

Den Wert halte ich persönlich für zu hoch.
 
M

maki

Gast
Ja, 256MiB lief auch bei mir (Tomcat Server mit einer Uralt Anwendung, Java 1.5), man müsste zB. schon sehr viele Klassen laden um 512MiB voll zu bekommen.

Aber das eigentliche Problem war ja das Java 6 den MaxPermSize nicht mehr kennt(?), zumindest wenn man der Fehlermeldung traut.
 

oltoko

Mitglied
maki hat gesagt.:
Was ist mit

-XX:permSize=512m

Den Wert halte ich persönlich für zu hoch.

Ich habs jetzt mal mit:

Code:
-XX:MaxPermSize=256m -XX:PermSize=128m

probiert. Das selbe Spiel :bahnhof:. Wobei ich auch den Fehler ein bisschen unverständlich finde. Unrecognized VM option ''. Ich habe das empfinden das zwischen den zwei Hochkommatas ja jetzt eigentlich stehen müsste was er nicht versteht. In dem Fall also MaxPermSize....
Ich habe jetzt mir auch nochmal die Doku zuu 1.6 durchgeschaut und tatsächlich scheint, wie wildcard schon erwähnt hat, diese Option von Release zu Releas nicht frei von tiefgreifenden Änderungen zu sein.
Sun hat gesagt.:
Options that are specified with -XX are not stable and are not recommended for casual use. These options are subject to change without notice.
.

Mmmh.... ich sags mal so, zur Zeit läuft der Server, solang man nicht das Projekt neu deployed. Jedoch, so gewinne ich auf jeden fall den Eindruck wenn ich mir die JVM des Geronimo mit jconsole anschaue, dass der PermSpace kontinuierlich steigt und deswegen die Gefahr besteht, daß mir alles einfach nach einer oder zwei Wochen abschmiert. Natürlich liegt der eigentliche Fehler, dass der PermGen wächst, an dem Framework das ich verwende (RAP), jedoch fehlt mir erstens das KnowHow um so weitgreifende Änderungen daran vorzunehmen und zweitens ist das ja auch der Job der eigentlichen Entwickler, alle Ressourcen wieder sauber freizugeben, oder zumindest so zu hinterlassen, dass der GC dies tun kann.
 

FArt

Top Contributor
maki hat gesagt.:
Ja, 256MiB lief auch bei mir (Tomcat Server mit einer Uralt Anwendung, Java 1.5), man müsste zB. schon sehr viele Klassen laden um 512MiB voll zu bekommen.

Die PermSize geht z.B. in Enterprise-Umgebungen gerne aus, wenn die Umgebung ein Feature wie "HotReDeployment" unterstützt. Hier kann es passieren, das über bestimmte Konstruke Klassen immer referenziert bleiben und somit nie vom GC weggeräumt werden. Dann wächst mit jedem Redeployment die Klassenanzahl (nur durch vermeintliche "Duplikate" ungebremst an...

Aber ob es einfach zu viele Klassen sind oder ein Fehler wie gerade beschrieben vorliegt: ein halbes Gig ist sehr wahrscheinlich übertrieben. In dem einen Fall wird die Grenze nie erreicht, in dem anderen Fall ist die Erhöhung des Speichers keine Lösung ;-)
 
M

maki

Gast
Stimmt FArt, das ist natürlich ein Szenario in dem sich der PermGen schnell füllt.

:toll:

@oltoko

Lass doch mal die MaxPermSize weg, vielleciht hilfts, ansonsten würde ich nochmal die JAVA_OPTS (oder war es die JAVAOPTS?) Umgebungsvariable probieren und normal starten.
 

oltoko

Mitglied
maki hat gesagt.:
Lass doch mal die MaxPermSize weg, vielleciht hilfts, ansonsten würde ich nochmal die JAVA_OPTS (oder war es die JAVAOPTS?) Umgebungsvariable probieren und normal starten.

Genau, die JAVA_OPTS ist das. Die hab ich schon seit längerem gesetzt, nur habe ich mich gewundert warum mir die jconsole nie den Wert angezeigt hat, den ich dort vergeben habe. Deswegen hab ich mir aus der batch Datei, mit der ich normal den Geronimo starte, mal den aufruf von oben rauskopiert um diesen einfach mal über die Konsole zu versuchen. Nur dann, wird mir der erwähnte Fehler angezeigt.
Ich werds jetzt mal einfach dabei belassen und das von FArt angesprochene "HotReDeployment" vermeiden und hoffen dass alles stabil läuft :D.

Achja, nur noch nebenbei. Unter Linux wird die JVM Fehlermeldung richtig ausgegeben: Unrecognized VM option 'PermSize=128m'[/code]
 
M

maki

Gast
Hab mir auch schon öfters Probleme eingehandelt wenn ich die Startskripte geändert habe, war immer ein gefummel.
 

oltoko

Mitglied
Ich starte ja schon die ganze Zeit von Hand. Und in das Script habe ich auch nur reingeschaut um zu schauen, wie das dort aufgerufen wird.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
R Startparameter für jar Allgemeine Java-Themen 6
D Verknüpfte Datei und Startparameter übergabe Allgemeine Java-Themen 6
Oneixee5 Für die RPi-Bastler ... Allgemeine Java-Themen 0
I PDF2Tiff für Fax Allgemeine Java-Themen 0
W Vergleichstool für xml-Dateien Tortoise-svn Verknüpfung Allgemeine Java-Themen 2
Zrebna Tipps für Organisation von Code-Reviews nach einem Pull Request. Allgemeine Java-Themen 5
Zrebna Bitte um Empfehlungen für "zeitlose" Bücher bzgl. Backend mit Spring und Beans Allgemeine Java-Themen 25
G Lesbare args für die main-Methode Allgemeine Java-Themen 6
B Algorithmus für Arbeit mit fehlenden Listenelementen? Allgemeine Java-Themen 1
kodela Eingabe für TextArray bedingt sperren Allgemeine Java-Themen 3
Karl_Der_Nette_Anfänger Hat wer ne Lösung für verknüpfte Postleitzahlen? (Baum/Wurzel Struktur) Allgemeine Java-Themen 11
R 11 GB File lesen ohne zu extrahieren Filedaten Bereich für Bereich adressieren dann mit Multi-Thread id die DB importieren Allgemeine Java-Themen 3
G KeyListener für JTextField Allgemeine Java-Themen 5
webracer999 Library für Textsuche (z. B. include/exclude, and/or)? Allgemeine Java-Themen 5
I Module-Info für Jar erzeugen Allgemeine Java-Themen 7
krgewb Java-Bibliothek für ONVIF Allgemeine Java-Themen 1
B Simpler Eventlistener für Tastaturtaste bauen? Allgemeine Java-Themen 13
G Eingegebenen Text Zeile für Zeile ausgeben lassen Allgemeine Java-Themen 11
E Key für TOTP Algorythmus(Google Authentificator) Allgemeine Java-Themen 0
S Formel für Sonnenwinkel in ein Programm überführen Allgemeine Java-Themen 11
M pfx-Zertifikat in Tomcat für SSL-Verschlüsselung nutzen Allgemeine Java-Themen 14
R Best Practice Erfahrungswerte für eine Migration von JSF nach Angular (oder anderes JS-Framework) Allgemeine Java-Themen 1
B HeapSort für Array of Strings funktioniert nur teilweise Allgemeine Java-Themen 3
jhCDtGVjcZGcfzug Klassen Was genau passiert hier? Kann mir das jemand bitte Zeile für Zeile erklären? Allgemeine Java-Themen 1
rosima26 Bester Sortieralgorithmus für kurze Arrays Allgemeine Java-Themen 40
S Mit Methoden kann man definieren für was <T> steht. Geht das auch irgendwie für Variablen? Allgemeine Java-Themen 12
MangoTango Operatoren while-Schleife für Potenz Allgemeine Java-Themen 3
B Lottospiel, genug Reihen tippen für 3 Richtige (Spaß mit Arrays)? Allgemeine Java-Themen 46
B Mit welchen Datentypen und Strukturierung am Besten dutzende Baccaratspiele Shcritt für Schritt durchsimulieren? Allgemeine Java-Themen 26
D Klassendesign für einen Pascal Interpreter Allgemeine Java-Themen 6
I OCR Library für Belegerkennung Allgemeine Java-Themen 7
farah GetterMathod für Farbkanäle Allgemeine Java-Themen 6
B Welcher Datentyp für sehr große Zahlenbereiche? Allgemeine Java-Themen 1
S Webservices für binäre Daten? Allgemeine Java-Themen 5
G Licence-Header für InHouse entwickelten Source Allgemeine Java-Themen 8
M Schleife für einen TicTacToe Computer Allgemeine Java-Themen 5
O git ignore für Intellji braucht es die .idea Dateien? Allgemeine Java-Themen 8
F Java Script für das Vorhaben das richtige? Allgemeine Java-Themen 9
M wiviel Java muss ich für die Berufswelt können ? Allgemeine Java-Themen 5
Robertop Datumsformat für GB ab Java 16 Allgemeine Java-Themen 1
Thallius Verschiedene entities für gleichen Code…. Allgemeine Java-Themen 8
OnDemand Zentrale "Drehscheibe" für verschiedene APIs Allgemeine Java-Themen 14
S Übergabe eines Sortierkriteriums für ein Artikel Array mittels BiPredicate<Artikel, Artikel> Allgemeine Java-Themen 13
F Streams als Alternative für dieses Problem ? Allgemeine Java-Themen 15
D SHA-3 für Java-version 1.8 Allgemeine Java-Themen 1
N Validator für einen SQL-Befehl Allgemeine Java-Themen 22
Muatasem Hammud Erstellung von Testdaten für Arrays Allgemeine Java-Themen 6
B Logikfehlersuche, das perfekte Lottosystem für 3 Richtige mit Arraylists? Allgemeine Java-Themen 71
G Methoden für die Zukunft sinnvoll? Allgemeine Java-Themen 4
M API für PLZ Umkreissuche Allgemeine Java-Themen 3
1Spinne JDK 8 für Eclipse installieren Allgemeine Java-Themen 5
Tobero Meine Funktion für das beinhalten eines Punktes in einem Kreis funktioniert nicht Allgemeine Java-Themen 5
L Methoden Parser für gängige Datumsformate? Allgemeine Java-Themen 1
H Interface PluginSystem ClassNotFound exception für library Klassen Allgemeine Java-Themen 10
N relativier Pfad für sqlite-Datenbank in Gradle/IntelliJ Allgemeine Java-Themen 2
buchfrau Anagram für beliebiges Wort Allgemeine Java-Themen 2
TonioTec Api für Datenaustausch zwischen Client und Server Allgemeine Java-Themen 0
W Suche Ursache für NPE - woher kommt sie? (Hilfe beim Debugging) Allgemeine Java-Themen 19
Kirby.exe Distanz Map für die Distanztransformation erstellen Allgemeine Java-Themen 1
F PI Regler für Heizung Allgemeine Java-Themen 7
8u3631984 Generelle Log4j.xml für alle Module Allgemeine Java-Themen 5
M Wie übergebe ich den Zähler für die Anzahl Rekursionsschritte korrekt? Allgemeine Java-Themen 2
B Login für User, der im Hintergrund Schedules ausführt Allgemeine Java-Themen 16
L RegEx für Teile einer Berechnung Allgemeine Java-Themen 14
S Java-Task-Management-Tool für Windows und Mac selber programmieren Allgemeine Java-Themen 4
M Java 2D Array für ein Grid erstellen ? Allgemeine Java-Themen 2
Z Welches GUI Framework für Java ist aktuell? Allgemeine Java-Themen 16
N Convert.FromBase64 von C# für Java Allgemeine Java-Themen 11
N fixed-keyword von C# für Java Allgemeine Java-Themen 6
O Suche Scripter für alt:V Project! Allgemeine Java-Themen 0
S Interface Design von HookUp oder Callback Methoden für eigenes Framework Allgemeine Java-Themen 9
O Suche Unterstützung für ein OpenSource-Projekt (grafischer Editor) Allgemeine Java-Themen 13
Kirby.exe Software für Graphische Visualisierung Allgemeine Java-Themen 20
B OOP Auslöser für NullPointerException Allgemeine Java-Themen 3
L Generator für einen Parser implementieren Allgemeine Java-Themen 13
DonMalte Ambitioniertes Projekt für Einsteiger & Motivierte Allgemeine Java-Themen 0
Kirby.exe Movement System für Spiel Allgemeine Java-Themen 13
Kirby.exe Framework für Game Design Allgemeine Java-Themen 8
W Alternative für Threads Allgemeine Java-Themen 6
S Rückgabe einer HttpURLConnection für eine Seite einlesen bei der man eingeloggt ist..? Allgemeine Java-Themen 5
Elyt Compiler-Fehler Datei kann nicht erstellt werden. Die Syntax für den Dateinamen etc. ist falsch. Allgemeine Java-Themen 2
Thallius Rätsel für Windows Profis Allgemeine Java-Themen 8
D OOP Gemeinsamen ID-Raum für zwei Klassen implementieren Allgemeine Java-Themen 7
D Input/Output Implementierung eines CommandHandlers/Parsers für viele Eingaben Allgemeine Java-Themen 26
Thallius Alternative für SwingWorker Allgemeine Java-Themen 5
I Lohnt sich heutzutage der Aufwand einer Portierung für MacOS Allgemeine Java-Themen 8
L Klassen Algorithmus für das folgende Problem entwickeln? Allgemeine Java-Themen 30
J Datenstruktur für eine Map erstellen Allgemeine Java-Themen 2
H OOP Setting(config) für Applikation sicheren? Allgemeine Java-Themen 9
OnDemand PDF Libary für Formulare Allgemeine Java-Themen 7
S Warmup für Lineare-Suche mit Zeitmessung Allgemeine Java-Themen 2
T Allgemeine Frage: GUI für 3D-Visualisierung Allgemeine Java-Themen 5
M Brainstorming für mein Projekt Allgemeine Java-Themen 30
K OOP Suche Hilfe + Erklärung für eine Hausaufgabe Allgemeine Java-Themen 1
F Was ist der Dateityp meines Parameters für die Main Methode. Allgemeine Java-Themen 6
C Bibliotheken für Algorithmische Geometrie Allgemeine Java-Themen 2
C Daten für Klassifikationsverfahren gewinnen Allgemeine Java-Themen 6
C code oder Bibliotheken für 2-Center Problem Allgemeine Java-Themen 4
I Overlay für Spiele Allgemeine Java-Themen 5
B Suche nach einem Testprogramm für meine BA Allgemeine Java-Themen 0

Ähnliche Java Themen

Neue Themen


Oben