Opened 9 years ago
Closed 9 years ago
#12114 closed defect (othersoftware)
Memory leak in JOSM
Reported by: | naoliv | Owned by: | team |
---|---|---|---|
Priority: | major | Milestone: | |
Component: | Core | Version: | |
Keywords: | Cc: |
Description
I was noting that, while I was editing, JOSM was getting slower.
Taking a look at top I saw that JOSM's memory usage was increasing:
VIRT RES SHR MEM% TIME+ Command 17.3G 7416M 43144 37.9 54:45.82 java -jar josm-latest.jar 17.4G 7625M 43352 38.9 56:46.82 java -jar josm-latest.jar 17.5G 7760M 45340 39.6 57:42.67 java -jar josm-latest.jar
I also noted high CPU spikes while doing simple operations (like creating one node).
Closing JOSM and running it again "fixes" it (until it gets slow again).
What could cause this?
What can I do to help and give more information about this?
JOSM:
Revision: 9017 Repository Root: http://josm.openstreetmap.de/svn Relative URL: ^/trunk Last Changed Author: bastiK Last Changed Date: 2015-11-16 23:07:49 +0100 (Mon, 16 Nov 2015) Build-Date: 2015-11-17 02:32:33 URL: http://josm.openstreetmap.de/svn/trunk Repository UUID: 0c6e7542-c601-0410-84e7-c038aed88b3b Last Changed Rev: 9017 Identification: JOSM/1.5 (9017 pt_BR) Linux Debian GNU/Linux testing (stretch) Memory Usage: 511 MB / 9102 MB (269 MB allocated, but free) Java version: 1.8.0_72-internal, Oracle Corporation, OpenJDK 64-Bit Server VM VM arguments: [-Dawt.useSystemAAFontSettings=on] Plugins: - Create_grid_of_ways (31603) - OpeningHoursEditor (31696) - PicLayer (31694) - RoadSigns (31694) - SimplifyArea (31694) - apache-commons (31718) - buildings_tools (31694) - conflation (0.1.8) - contourmerge (1014) - download_along (31603) - editgpx (31603) - ejml (31756) - geotools (31755) - imagery_offset_db (31694) - importvec (31694) - jts (31603) - log4j (31603) - measurement (31694) - merge-overlap (31732) - opendata (31766) - pbf (31694) - pdfimport (31694) - poly (31694) - reverter (31694) - scripting (30722) - todo (29154) - turnrestrictions (31694) - undelete (31603) - utilsplugin2 (31694)
Attachments (1)
Change History (22)
comment:1 by , 9 years ago
comment:3 by , 9 years ago
Milestone: | → 15.11 |
---|---|
Priority: | normal → major |
let's try to fix it in this milestone.
follow-up: 6 comment:4 by , 9 years ago
MAT is more memory hungry than JOSM :-)
It seems to leak while adding nodes.
For example, tracing a wood area I saw that the memory increases (a lot), while JOSM gets slower.
And I need some help of what (and how) I export the reports.
comment:5 by , 9 years ago
I received the HPROF file from naoliv. Few observations:
- HPROF file is quite big (3.5GB) though Java Heap is quite small (500MB). Looks like quite a lot of memory is allocated offheap (probably by GTK?)
- 460
javax.swing.JTree$AccessibleJTree$AccessibleJTreeNode
occupy around 300MB of memory - This JTree Nodes come from
org.openstreetmap.josm.gui.dialogs.CommandListMutableTreeNode
(there is also few houndred instances of them) - Each of
javax.swing.JTree$AccessibleJTree$AccessibleJTreeNode
retains around 1MB of memory - Most of the memory is retained within
DefaultMutableTreeNode
, where there areVectors
, backed byObject[]
arrays
It looks like the undo tree is leaking something here... I'll try to reproduce
comment:7 by , 9 years ago
Some further thoughts after trying to reproduce:
- I did create empty layer, and made dozens of ways, to get around 500 actions in undo stack
- Memory usage was around 66MB (vs 426MB what observed naoliv)
- I did not spot any
javax.swing.JTree$AccessibleJTree$AccessibleJTreeNode
in my dump. javax.swing.JTree$AccessibleJTree$AccessibleJTreeNode
in naoliv dump are allocated in native stack- Each
javax.swing.JTree$AccessibleJTree$AccessibleJTreeNode
references different instances ofjavax.swing.tree.DefaultMutableTreeNode
(each retains around 1MB heap)
My wild guess is maybe there is some of native libraries is leaking memory. libgtk? libgnome?
@naoliv:
Did you updated your system recently? Can you reinstall all openjdk dependencies? I don't have other suspects for the reason of this behaviour.
comment:8 by , 9 years ago
Reinstalled the packages and updated related libgtk packages from testing to unstable (in Debian), but I still see the same behavior.
But with ~/.josm
renamed the memory issue seems to be gone.
Could some plugin cause this? Some option enabled or disabled in JOSM?
comment:9 by , 9 years ago
If starting with fresh ~/.josm
helps, then please check if you can reproduce the problem after installing all your plugins.
If this is the case try to bisect plugins to find the one responsible. I don't have yet any idea which one could be twosome.
comment:10 by , 9 years ago
I've found the culprit.
With a fresh ~/.josm
, no plugins nor anything else, but adding these two options in preferences.xml
(it really took some time to pinpoint this):
<tag key='commandstack.minimized' value='true'/> <tag key='commandstack.visible' value='true'/>
I can reproduce the same memory problem.
It seems to match what wiktorn saw with the undo stack in my HPROF.
comment:11 by , 9 years ago
I tried to reproduce this to no avail.
Java version (just downloaded from Oracle site, 64bit version):
java -version java version "1.8.0_66" Java(TM) SE Runtime Environment (build 1.8.0_66-b17) Java HotSpot(TM) 64-Bit Server VM (build 25.66-b17, mixed mode)
Debian 8.2 (jessie)
JOSM: 9024.
The way I tried to reproduce the problem:
- Make sure, that
preferences.xml
containscommandstack.minimized
andcommandstack.visible
set to true - Run JOSM (-Xmx512m)
- Create new layer
- Make a dozen of ways, with a lot of nodes, to get ~500 actions in command stack
- Verify RES size of application (if it is greater than 512m)
- Check heap size using visualvm
For now, my results are, that I see around 300M of RES size, and ~100MB of Java heap usage, that drops to 40MB after GC.
@naoliv:
Where did you got your java runtime? It looks like you're quite ahead (1.8.0_72-internal) of what's published by Oracle (1.8.0_66)
comment:12 by , 9 years ago
The one provided by Debian:
$ LC_ALL=C apt-cache policy openjdk-8-jre:amd64 openjdk-8-jre: Installed: 8u72-b05-1 Candidate: 8u72-b05-1 Version table: *** 8u72-b05-1 500 500 http://httpredir.debian.org/debian unstable/main amd64 Package
Also available at testing.
comment:13 by , 9 years ago
And just complementing, I also tested with
$ java -version java version "1.7.0_91" OpenJDK Runtime Environment (IcedTea 2.6.2) (7u91-2.6.2-1) OpenJDK 64-Bit Server VM (build 24.91-b01, mixed mode)
And I see the same problem.
comment:14 by , 9 years ago
Could you please provide the minimum config your tried the test with. Sometimes little details are overlooked in descriptions.
comment:15 by , 9 years ago
I have removed all the ~/.josm
dir, started JOSM once (so I could get the default preference file, like below) and closed it, without doing anything:
<?xml version="1.0" encoding="UTF-8"?> <preferences xmlns="http://josm.openstreetmap.de/preferences-1.0" version="9024"> <tag key='cache.capabilities1637351842' value='1447966910'/> <tag key='cache.motd.html' value='1447966909'/> <tag key='cache.motd.html.java' value='1.8.0_72-internal'/> <tag key='cache.motd.html.lang' value='Pt_BR:'/> <tag key='cache.motd.html.version' value='9024'/> <maps key='imagery.entries'> <map> <tag key='name' value='Imagem aérea do Bing'/> <tag key='id' value='Bing'/> <tag key='type' value='bing'/> <tag key='url' value='http://www.bing.com/maps/'/> <tag key='max-zoom' value='22'/> <tag key='icon' value=''/> <tag key='noTileHeaders' value='{"X-VE-Tile-Info":"no-tile"}'/> <tag key='metadataHeaders' value='{"X-VE-TILEMETA-CaptureDatesRange":"Capture Date"}'/> </map> <map> <tag key='name' value='MapQuest Open Aerial'/> <tag key='id' value='mapquest-oa'/> <tag key='type' value='tms'/> <tag key='url' value='http://oatile{switch:1,2,3,4}.mqcdn.com/tiles/1.0.0/sat/{zoom}/{x}/{y}.png'/> <tag key='attribution-text' value='Tiles Courtesy of MapQuest. Portions Courtesy NASA/JPL-Caltech and U.S. Depart. of Agriculture, Farm Service Agency'/> <tag key='attribution-url' value='http://open.mapquest.com/'/> <tag key='icon' value=''/> <tag key='noTileHeaders' value='{"ETag":".*?:OC4CjEZcEJv8Az5u7fOqgEP\\+NpkA\""}'/> </map> <map> <tag key='name' value='OpenStreetMap (Mapnik Branco & Preto)'/> <tag key='id' value='osm-mapnik-black_and_white'/> <tag key='type' value='tms'/> <tag key='url' value='http://{switch:a,b,c}.www.toolserver.org/tiles/bw-mapnik/{zoom}/{x}/{y}.png'/> <tag key='attribution-text' value='© OpenStreetMap contributors, CC-BY-SA'/> <tag key='attribution-url' value='https://openstreetmap.org/'/> <tag key='max-zoom' value='18'/> <tag key='icon' value=''/> </map> <map> <tag key='name' value='OpenStreetMap (Standard layer)'/> <tag key='id' value='standard'/> <tag key='type' value='tms'/> <tag key='url' value='https://{switch:a,b,c}.tile.openstreetmap.org/{zoom}/{x}/{y}.png'/> <tag key='attribution-text' value='© OpenStreetMap contributors, CC-BY-SA'/> <tag key='attribution-url' value='https://openstreetmap.org/'/> <tag key='max-zoom' value='19'/> <tag key='icon' value=''/> </map> <map> <tag key='name' value='Satélite Mapbox'/> <tag key='id' value='Mapbox'/> <tag key='type' value='tms'/> <tag key='url' value='http://{switch:a,b,c}.tiles.mapbox.com/v4/openstreetmap.map-inh7ifmo/{zoom}/{x}/{y}.png?access_token=pk.eyJ1Ijoib3BlbnN0cmVldG1hcCIsImEiOiJncjlmd0t3In0.DmZsIeOW-3x-C5eX-wAqTw'/> <tag key='max-zoom' value='19'/> <tag key='icon' value=''/> <tag key='noTileHeaders' value='{"ETag":"\"067736a547cafe90014b4e59b6510abe\""}'/> </map> </maps> <list key='imagery.layers.addedIds'> <entry value='Bing'/> <entry value='Mapbox'/> <entry value='mapquest-oa'/> <entry value='osm-mapnik-black_and_white'/> <entry value='standard'/> </list> <list key='imagery.layers.default'> <entry value='http://oatile{switch:1,2,3,4}.mqcdn.com/tiles/1.0.0/sat/{zoom}/{x}/{y}.png'/> <entry value='http://www.bing.com/maps/'/> <entry value='http://{switch:a,b,c}.tiles.mapbox.com/v4/openstreetmap.map-inh7ifmo/{zoom}/{x}/{y}.png?access_token=pk.eyJ1Ijoib3BlbnN0cmVldG1hcCIsImEiOiJncjlmd0t3In0.DmZsIeOW-3x-C5eX-wAqTw'/> <entry value='http://{switch:a,b,c}.www.toolserver.org/tiles/bw-mapnik/{zoom}/{x}/{y}.png'/> <entry value='https://{switch:a,b,c}.tile.openstreetmap.org/{zoom}/{x}/{y}.png'/> </list> <tag key='mappaint.renderer-class-name' value='org.openstreetmap.josm.data.osm.visitor.paint.StyledMapRenderer'/> <list key='mappaint.style.known-defaults'> <entry value='resource://styles/standard/elemstyles.mapcss'/> <entry value='resource://styles/standard/potlatch2.mapcss'/> </list> <list key='mirror.https://josm.openstreetmap.de/maps'> <entry value='1447966911453'/> <entry value='/home/naoliv/.josm/cache/mirror_https___josm.openstreetmap.de_maps'/> </list> <tag key='validated.ipv6' value='true'/> </preferences>
Then edited preferences.xml
and inserted the two commandstack
lines after cache.motd.html.version
:
<?xml version="1.0" encoding="UTF-8"?> <preferences xmlns="http://josm.openstreetmap.de/preferences-1.0" version="9024"> <tag key='cache.capabilities1637351842' value='1447966910'/> <tag key='cache.motd.html' value='1447966909'/> <tag key='cache.motd.html.java' value='1.8.0_72-internal'/> <tag key='cache.motd.html.lang' value='Pt_BR:'/> <tag key='cache.motd.html.version' value='9024'/> <tag key='commandstack.minimized' value='true'/> <tag key='commandstack.visible' value='true'/> <maps key='imagery.entries'> (...)
And then started JOSM again, created an empty layer and started to draw some ways.
comment:16 by , 9 years ago
Ok, with freshly installed Debian sid (unstable) I am able to reproduce the problem. Having command stack of 236 commands, I see RES size of 1g (though I had -Xmx512m) and I see major slowdown of node creation.
Looks like Debian/GNOME/GTK problem to me.
comment:17 by , 9 years ago
And one more thing. Running JOSM on Debian sid/unstable, but using Oracle JDK (downloaded from Oracle webpage):
java -version java version "1.8.0_65" Java(TM) SE Runtime Environment (build 1.8.0_65-b17) Java HotSpot(TM) 64-Bit Server VM (build 25.65-b01, mixed mode)
I can not reproduce the bug
comment:19 by , 9 years ago
Replying to bastiK:
Oh, what fun, "write once, debug everywhere".
After checking debian package structure, I'm quite convinced, that this is Java bug introduced somewhere between 65b17 and 72b05.
I'll try later to fill a report to Oracle with some unit test.
comment:20 by , 9 years ago
Milestone: | 15.11 |
---|
comment:21 by , 9 years ago
Resolution: | → othersoftware |
---|---|
Status: | new → closed |
I failed to create small unit test that would show the case.
But I've tried building openjdk on my own on, using sources provided for Debian/stretch (apt-get source openjdk-8-jdk).
To my surprise, it works, but only if I do not use binaries generated for packages, but straight from the build process (build/images/j2sdk-image/).
I've reported this to Debian under:
https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=806563
Your memory usage looks huge. I was recently fighting with unmotivated high memory usage by imagery layers and I think, that I've nailed all the problems already in [9004].
What I usually use, to debug such situations is to run:
https://eclipse.org/mat/
Memory analysis tool. It connects to running application, dumps memory image, and provides some automated reports (i.e. Suspected leaks) which point to specific objects responsible for high memory usage.
If it's possible, keep the
*hprof
file (which might be quite huge in your case), but it might be useful for further inspection, who is responsible for memory mismanagement.