Probleme mit dem Java heap

Status
Nicht offen für weitere Antworten.
G

Gast2

Gast
Hi,
ich habe ein großes Problem mit einem memory leak.
Mein Java heap space wächst und wächst bis schließlich eine Out of Memory Exception kommt.
Das Programm ist eine rel. große Swinganwendung mit ca. 20k LoC. Ich habe leider keine Erfahrung mit memory leaks, daher melde ich mich hier und hoffe darauf dass mir jemand helfen kann :)

Hier einige kurze Infos zu meinem Problem:
Wie gesagt wächst der heap space stetig an bis schließlich das Programm abschmiert.
Ich habe mithilfe von jhat und jmap einen kurzen Blick in den heap geworfen.

12007 instances of class com.mysql.jdbc.ByteArrayRow
10700 instances of class com.mysql.jdbc.ConnectionPropertiesImpl$BooleanConnectionProperty
2800 instances of class com.mysql.jdbc.ConnectionPropertiesImpl$StringConnectionProperty
2500 instances of class com.mysql.jdbc.ConnectionPropertiesImpl$IntegerConnectionProperty
1785 instances of class com.mysql.jdbc.Buffer
1334 instances of class com.mysql.jdbc.Field
832 instances of class com.mysql.jdbc.JDBC4ResultSet
829 instances of class [Lcom.mysql.jdbc.Field;
424 instances of class com.mysql.jdbc.RowDataStatic
328 instances of class com.mysql.jdbc.StatementImpl
300 instances of class com.mysql.jdbc.ConnectionPropertiesImpl$MemorySizeConnectionProperty
179 instances of class com.mysql.jdbc.log.StandardLogger
100 instances of class com.mysql.jdbc.ConnectionPropertiesImpl$LongConnectionProperty
99 instances of class com.mysql.jdbc.JDBC4Connection
99 instances of class com.mysql.jdbc.JDBC4DatabaseMetaData
98 instances of class com.mysql.jdbc.MysqlIO
98 instances of class com.mysql.jdbc.StandardSocketFactory
98 instances of class com.mysql.jdbc.util.ReadAheadInputStream
94 instances of class cnc.gui.Mainframe$3
85 instances of class com.mysql.jdbc.jdbc2.optional.JDBC4ConnectionWrapper
85 instances of class com.mysql.jdbc.jdbc2.optional.JDBC4MysqlPooledConnection
85 instances of class com.mysql.jdbc.jdbc2.optional.JDBC4StatementWrapper
82 instances of class cnc.gui.ConnectionsDialog$1
66 instances of class com.mysql.jdbc.VersionedStringProperty
53 instances of class org.jdesktop.application.ApplicationAction
49 instances of class $Proxy3
41 instances of class cnc.util.listItems.ConnectionListItem
Hier ein kleiner Ausschnitt aller Instanzen (nach ca. 10min Laufzeit). Hier direkt meine erste Frage, sind zahlen wie 10.000 bzw. 12.000 normal?

Da ich mit jmap nicht viel weiter gekommen bin habe ich den Eclipse Memory Analyzer angeschmissen, der mir dann folgendes ausgegeben hat:
The class "java.lang.ref.Finalizer", loaded by "<system class loader>", occupies 7.435.408 (41,44%) bytes. The memory is accumulated in one instance of "java.lang.ref.Finalizer" loaded by "<system class loader>".

Keywords
java.lang.ref.Finalizer
41,44% werden von Finalizer Objekten verbraucht? Finalizer hat doch irgendwas mit Garbage Collection zu tun, oder nicht?

Darauf hin habe ich meinen Quellcode dahingehend modifiziert und führe manuell per System.gc() die Garbage Collection durch. Wenn ich jetzt mal ein Profiling starte sieht es so aus, als ob nach jeder gc der heap wieder auf ~15MB reduziert wird, es scheint also dann nichtmehr zu einer Out of Memory Exception zu kommen.

Wäre es unter Umständen ungünstig wenn ich z.b. alle 60Minuten mal die Garbage Collection anschmeiße um so den Heap wieder auf die "normalen" 15MB zu reduzieren?
Ich Frage mich außerdem warum Java das nicht automatisch macht, wenn doch soviel "Müll" im Speicher liegt?!

Das non plus ultra wäre natürlich wenn mir jemand einen Tipp geben könnte um das Übel an der Wurzel zu packen und das anwachsen des Heaps zu verhindern. :)
 

Marco13

Top Contributor
44% sind in diesem Fall ja nur 7 MB ... Mehr als den Tipp, nochmal genauer mit dem Memory Analyzer zu gucken, und zu überprüfen, ob irgendwo etwas angelegt wird, was eine "ByteArrayRow" erstellt, und das dann in eine Collection gelegt wird, kann ich anhand des geposteten auch nicht geben.
Aber einen wichtigen Hinweis noch: Es sollte NIE (NIE) notwendig sein, System.gc() aufzurufen!
 
B

bygones

Gast
mit wieviel MB startest du denn die anwendung ?

wenn irgendwo du mal eben zig millionen datensaetze aus einer DB laedst oder so und moeglichweise sonstiges noch offen hast koennten die 64M standart knapp werden...

einfach mal mehr speicher der VM geben ?
 
G

Gast2

Gast
mit wieviel MB startest du denn die anwendung ?

wenn irgendwo du mal eben zig millionen datensaetze aus einer DB laedst oder so und moeglichweise sonstiges noch offen hast koennten die 64M standart knapp werden...
Ich starte die VM mit dem Standardwert, sollten 256MB sein (zumindest schmiert mir das Programm ab sobald der heap größer als 256MB wird).
Die Datenbank ist eigentlich nicht sehr groß, 5 Tabellen, 4 davon mit <20 Datensätze, eine mit ~300 Datensätzen. In der großen Datenbank fallen pro Zeile vllt allerhöchstens 10kb an. Eigentlich sogar nur viel weniger.

einfach mal mehr speicher der VM geben ?
Ich kann mir schwer vorstellen dass mein Programm mehr als 256MB speicher braucht, ich schätze wenn ich dem Prog mehr Speicher zur Verfügung stelle dauerts halt nur etwas länger bis alles voll ist :bae:

Schließt du deine Connections nicht?

99 instances of class com.mysql.jdbc.JDBC4Connection

Doch. Ich habe gestern erst alles was die Datenbank betrifft umgeschrieben und bin von einer Eigenimplementierung eines connection pool auf den cp vom treiber umgestiegen, weil ich schon vorher vermutet habe dass die Datenbank da irgend nen humbug veranstaltet. Hat leider nichts geholfen.
Ich schließe alle ResultSets, Statements und Connections wenn diese nichtmehr gebraucht werden.

44% sind in diesem Fall ja nur 7 MB ... Mehr als den Tipp, nochmal genauer mit dem Memory Analyzer zu gucken, und zu überprüfen, ob irgendwo etwas angelegt wird, was eine "ByteArrayRow" erstellt, und das dann in eine Collection gelegt wird, kann ich anhand des geposteten auch nicht geben.
Aber einen wichtigen Hinweis noch: Es sollte NIE (NIE) notwendig sein, System.gc() aufzurufen!
Ok, ich werde mir das dann nochmal genauer anschauen müssen. Und dass man System.gc() nicht aufrufen sollte seh ich ein, aber wenns hilft? :p
 
G

Gast2

Gast
So schließe ich meine Verbindungen:

Java:
try {
    rs.close();
    rs = null;
    myStmt.close();
    myStmt = null;
    myCon.close();
    myCon = null;
} catch (SQLException sqle) {
    logger.error(sqle);
}

Um ne neue Verbindung zu holen wird diese Methode aufgerufen:

Java:
public static Connection getConnection() {
        Connection con = null;
        try {
            con = dataSource.getPooledConnection().getConnection();
        } catch (SQLException sqle) {
            logger.error("Fehler beim Verbinden zur Datenbank");
            logger.debug("Username: " + dataSource.getUser());
            logger.debug("Password: " + dataSource.getPasswordCharacterEncoding());
            logger.debug("URL: " + dataSource.getUrl());
        }
        return con;
    }
datasource ist vom Typ MysqlConnectionPoolDataSource. In der API steht, dass durch den Aufruf von Connection.close(); die Verbindung zurück in den Pool gelegt wird. Ich kann mir höchstens vorstellen, dass der connection pool der Meinung ist dass die Verbindungen offen gelassen werden sollten?!
 
B

bygones

Gast
So schließe ich meine Verbindungen:

Java:
try {
    rs.close();
    rs = null;
    myStmt.close();
    myStmt = null;
    myCon.close();
    myCon = null;
} catch (SQLException sqle) {
    logger.error(sqle);
}
im falle einer exception schliesst du nix... das setzen auf null sollte eigentlich unnuetz sein
 

tfa

Top Contributor
Ich kann mir höchstens vorstellen, dass der connection pool der Meinung ist dass die Verbindungen offen gelassen werden sollten?!
Das haben Connection-Pools so an sich. Allerdings bleiben nur eine gewisse Anzahl Connections offen, je nachdem, wei der Pool konfiguriert ist. Keine Ahnung wie das bei dem MysqlConnectionPoolDataSource funktioniert. Wieso benutzt du den? Verwenden einen Technologie-unabhängigen Pool, dann hast du später keine Probleme, wenn du mal die DB wechseln willst.
 
G

Gast2

Gast
Das haben Connection-Pools so an sich. Allerdings bleiben nur eine gewisse Anzahl Connections offen, je nachdem, wei der Pool konfiguriert ist. Keine Ahnung wie das bei dem MysqlConnectionPoolDataSource funktioniert. Wieso benutzt du den? Verwenden einen Technologie-unabhängigen Pool, dann hast du später keine Probleme, wenn du mal die DB wechseln willst.

Aber 99 Verbindungen aufrecht zu erhalten halte ich für ein wenig übertrieben ;)
Ich habe in der API nichts gefunden wie ich die maximale Anzahl der Verbindungen beschränken kann. Aber darin liegt wohl auch nicht unbedingt das Problem mit dem memory leak :/
 

tfa

Top Contributor
Aber 99 Verbindungen aufrecht zu erhalten halte ich für ein wenig übertrieben ;)
Ich auch.
Ich habe in der API nichts gefunden wie ich die maximale Anzahl der Verbindungen beschränken kann.
Das ist schlecht. Dann schmeiß testweise den Pool ganz raus und versuche es nur mit einer Connection.
Aber darin liegt wohl auch nicht unbedingt das Problem mit dem memory leak :/
Wie kommst du darauf?
 
G

Gast2

Gast
Habe den Pool jetzt rausgenommen und durch eine MysqlDataSource ersetzt. Das ganze auf nur eine Verbindung zu begrenzen ist nicht möglich weil mehrere Threads auf die DB zugreifen müssen.
Aber durch den Wegfall des pools sollten ja jetzt die Verbindungen ganz geschlossen werden.

Hier im Anhang nen Screenshot vom Profiling. Die "Hügel" kommen dadurch zustande dass ich dem Programm ein bißchen was zutun gegeben habe und er da jeweils immer ein Fenster öffnet.
Trotzdem kann man glaub ich erkennen dass ne kleine Steigung zu erkennen ist.
 

tfa

Top Contributor
Keine Ahnung was eine MysqlDataSource macht. Vielleicht betreibt die auch Pooling.
Ich verwende DBCP, das funktioniert.

Wenn du den GC aufrufst, bleiben dann deine 99 Connections bestehen?
 
G

Gast2

Gast
Danke euch, ich habe nun auf DBCP umgestellt und es scheint so, dass sich das Problem damit erledigt hat. Zumindest bleibt der Heap im "Leerlauf" nun konstant und steigt nicht weiter.
Werde wohl noch den rest durchtesten müssen, aber das hat schonmal geholfen :)
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
MQue Java Heap space Probleme Allgemeine Java-Themen 26
B Java Reflection Probleme beim wehcselseitigen Referenzieren zweier Klassen/Objekte Allgemeine Java-Themen 14
O Leerzeichen und Umlaute im Pfad einer Java Applikation machen Probleme Allgemeine Java-Themen 13
B Input/Output Probleme beim Ausführen von Shell-Befehlen mit Java Allgemeine Java-Themen 28
F SQLite mit Java / Probleme beim INSERT Befehl Allgemeine Java-Themen 4
S Probleme mit unterschiedlichen Java-Versionen (Mac OS X 10.11) Allgemeine Java-Themen 0
VfL_Freak Große und seltsame Probleme nach Java-Update auf V1.8.0_91 Allgemeine Java-Themen 3
P Probleme mit Grafik (Java) Allgemeine Java-Themen 6
J Probleme mit der Java-Runtime Allgemeine Java-Themen 10
F Java Native/Shared Library (.so) laden macht Probleme Allgemeine Java-Themen 3
J Java Progressbar & Download Probleme Allgemeine Java-Themen 10
S Probleme mit JAVA-Installation Allgemeine Java-Themen 3
H JAVA-ARCHIV-PROBLEME - pls help :( Allgemeine Java-Themen 4
P Java Probleme - java.lang.Thread.run(Unkown Source) Allgemeine Java-Themen 10
i<3java [Groovy/Grails](oder auch java) Mögliche Performance Probleme bei Mailversendung Allgemeine Java-Themen 2
hdi Probleme mit Java/Eclipse x64 Allgemeine Java-Themen 2
D Probleme mit der java benutzung Allgemeine Java-Themen 39
S Vista 64 BIT + Java Probleme Allgemeine Java-Themen 2
Z Probleme mit Java unter Vista/ Windows 7 Allgemeine Java-Themen 12
H Probleme! Mac Os und Java Update Allgemeine Java-Themen 3
J Eclipse Java-Project und CVS - massive Probleme Allgemeine Java-Themen 2
A Java Bridge probleme - einbinden fehlgeschlagen/php kennt "java_required" nicht Allgemeine Java-Themen 3
E Probleme mit Java und Vista Allgemeine Java-Themen 16
J Java Plugin probleme beim Laden? Allgemeine Java-Themen 3
T Java Applet PDF erstellen mit iText, Probleme mit Pfad Allgemeine Java-Themen 1
K Probleme mit JAVA Webstart Allgemeine Java-Themen 8
R Java Printing Probleme auf dem Mac Allgemeine Java-Themen 3
M Quicktime Java Probleme Allgemeine Java-Themen 2
P pythonscripte aus java aufrufen, probleme mit berechtigungen Allgemeine Java-Themen 3
N Probleme mit Java Editor - Funktioniert gar nicht Allgemeine Java-Themen 4
W Probleme beim Ausführen einer Java Klasse auf Kommandozeile Allgemeine Java-Themen 17
B Probleme mit Java-Programm Allgemeine Java-Themen 21
M Probleme mit Cipher: java.security.InvalidKeyException Allgemeine Java-Themen 1
K Probleme mit Java Allgemeine Java-Themen 4
S Probleme mit Java Versionen und Commapi Allgemeine Java-Themen 2
G Java Media Framework - Probleme Allgemeine Java-Themen 8
G Probleme mit java.mail Allgemeine Java-Themen 2
A Probleme bei der Berechnung von Pi! Java Problem Allgemeine Java-Themen 2
A Probleme mit Umlauten in der Java RE unter Debian Linux Allgemeine Java-Themen 2
C Probleme beim Starten eines Java-Programms Allgemeine Java-Themen 2
T Jetty Konfiguration - Probleme mit Java Klassen Allgemeine Java-Themen 2
C Probleme beim Erstellen eines runnable-jar files Allgemeine Java-Themen 1
S Umstellung von File auf Path - Probleme mit Stream Allgemeine Java-Themen 5
C Probleme mit javax.mail.Session Allgemeine Java-Themen 8
M tomcat probleme Allgemeine Java-Themen 1
N Division macht Probleme Allgemeine Java-Themen 14
MarvinsDepression Probleme mit relativem Dateipfad Allgemeine Java-Themen 1
G Geotools Probleme nach PC-Wechsel Allgemeine Java-Themen 6
nibe1501 GUI Probleme Allgemeine Java-Themen 16
C Probleme mit dem WindowBuilder Allgemeine Java-Themen 3
P Selenium . Probleme ein Iron Icon Element anzusprechen Allgemeine Java-Themen 2
B Compiler-Fehler Probleme beim Kompilieren mit Jsoup Allgemeine Java-Themen 8
K VisualVM Profiling Remote Probleme Allgemeine Java-Themen 1
M Probleme bei Eclipse wenn ich entpacke Allgemeine Java-Themen 15
D Regex Probleme Allgemeine Java-Themen 2
M Probleme jar datei. Allgemeine Java-Themen 2
L Vererbung Verständnis Probleme Vererbung Allgemeine Java-Themen 2
Dann07 Probleme mit OpenAL Allgemeine Java-Themen 0
V Threads Probleme beim Aufrufen von Methoden einer anderen Klasse (Threads) Allgemeine Java-Themen 14
V Compiler-Fehler Online Compiler Probleme Allgemeine Java-Themen 4
M Probleme mit Negamax-Algorithmus Allgemeine Java-Themen 29
M Probleme mit BigDecimal Allgemeine Java-Themen 1
T Probleme mit NumberFormat Allgemeine Java-Themen 5
J Probleme exe-Start mit Task Scheduler Allgemeine Java-Themen 1
J Probleme beim einbinden von Zip4j library Allgemeine Java-Themen 6
F Variablen Palindromzahl (Probleme mit Methode) Allgemeine Java-Themen 9
K Data Konverter - Probleme mit Byte[] Kodierung Allgemeine Java-Themen 3
T Probleme mit dem Pfad zum Propertie file Allgemeine Java-Themen 7
H Swing HashMap zu Tabelle macht mir Probleme Allgemeine Java-Themen 4
Neoline Interpreter-Fehler Probleme mit Arrays.toString Allgemeine Java-Themen 7
J Erste Schritte Probleme mit der Hauptklasse Allgemeine Java-Themen 14
J Tetris Probleme bei Klassen Allgemeine Java-Themen 14
J MinMax VierGewinnt Probleme Allgemeine Java-Themen 22
J Probleme mit CodeCoverage und Lombok Equals Allgemeine Java-Themen 1
S Eclipse Probleme beim Implementieren / Ausführen von jUnit 5-Test Suites Allgemeine Java-Themen 14
R Snake Probleme Allgemeine Java-Themen 2
A Probleme beim Verstehen einer Aufgabenstellung Allgemeine Java-Themen 11
RalleYTN 3D Objekt Translation basierend auf Rotation (Probleme mit Z Rotation) Allgemeine Java-Themen 0
Bluedaishi Druck Probleme mit PDF dateien Allgemeine Java-Themen 4
G Ant Probleme bei einer Installation die Apache ant+ivy verwendet Allgemeine Java-Themen 14
E TableView Probleme Allgemeine Java-Themen 7
perlenfischer1984 Probleme beim Mocken Allgemeine Java-Themen 6
S Kaffemaschine Programmierung Probleme Allgemeine Java-Themen 2
K Threads Runtime und Process Probleme Allgemeine Java-Themen 3
S Event Handling keyPressed()-Probleme Allgemeine Java-Themen 2
R probleme beim starten von jar unter linux Allgemeine Java-Themen 2
H Probleme mit DAY_OF_WEEK Allgemeine Java-Themen 4
Arif Probleme mit NullPointerException Allgemeine Java-Themen 2
E Probleme mit nextInt() und Exception Allgemeine Java-Themen 35
Streeber Probleme mit AWT-EventQueue: ArrayList Elemente hinzufügen Allgemeine Java-Themen 1
D Performance-Probleme mit Joda-Time Allgemeine Java-Themen 3
M Probleme beim rechnen, bei Zahlen mit führenden Nullen. Allgemeine Java-Themen 7
RalleYTN Probleme mit Encrypting Allgemeine Java-Themen 10
M Probleme mit Schriftarten PDFBox Allgemeine Java-Themen 3
G Probleme mit BufferedWriter und URL Allgemeine Java-Themen 4
S Probleme mit meinem MacBook Pro DRINGEND HILFE erbeten! Allgemeine Java-Themen 17
Androbin Interpreter-Fehler Probleme mit Rekursion - StackOverflowError Allgemeine Java-Themen 8
E JCuda-0.6.5 Probleme beim ausführen der Datei Allgemeine Java-Themen 0
M Runtime.exec() verursacht auf manchen Systemen Probleme - Ursache unklar Allgemeine Java-Themen 2
W JNDI - LDAP - Probleme beim editieren von Usern Allgemeine Java-Themen 0

Ähnliche Java Themen

Neue Themen


Oben