Modify

Opened 5 years ago

Closed 5 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)

hs_err_pid3394.log (75.6 KB) - added by wiktorn 5 years ago.
hs_err* file generated on debian/unstable

Download all attachments as: .zip

Change History (22)

comment:1 Changed 5 years ago by wiktorn

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.

comment:2 Changed 5 years ago by naoliv

Really good to know this.
I will get back tomorrow with the analysis.

comment:3 Changed 5 years ago by Don-vip

Milestone: 15.11
Priority: normalmajor

let's try to fix it in this milestone.

comment:4 Changed 5 years ago by naoliv

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.

https://i.imgur.com/vb6smiM.jpg

Last edited 5 years ago by stoecker (previous) (diff)

comment:5 Changed 5 years ago by wiktorn

I received the HPROF file from naoliv. Few observations:

  1. 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?)
  2. 460 javax.swing.JTree$AccessibleJTree$AccessibleJTreeNode occupy around 300MB of memory
  3. This JTree Nodes come from org.openstreetmap.josm.gui.dialogs.CommandListMutableTreeNode (there is also few houndred instances of them)
  4. Each of javax.swing.JTree$AccessibleJTree$AccessibleJTreeNode retains around 1MB of memory
  5. Most of the memory is retained within DefaultMutableTreeNode, where there are Vectors, backed by Object[] arrays

It looks like the undo tree is leaking something here... I'll try to reproduce

Last edited 5 years ago by wiktorn (previous) (diff)

comment:6 in reply to:  4 Changed 5 years ago by Don-vip

Replying to naoliv:

:D

comment:7 Changed 5 years ago by wiktorn

Some further thoughts after trying to reproduce:

  1. I did create empty layer, and made dozens of ways, to get around 500 actions in undo stack
  2. Memory usage was around 66MB (vs 426MB what observed naoliv)
  3. I did not spot any javax.swing.JTree$AccessibleJTree$AccessibleJTreeNode in my dump.
  4. javax.swing.JTree$AccessibleJTree$AccessibleJTreeNode in naoliv dump are allocated in native stack
  5. Each javax.swing.JTree$AccessibleJTree$AccessibleJTreeNode references different instances of javax.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 Changed 5 years ago by naoliv

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?

Last edited 5 years ago by naoliv (previous) (diff)

comment:9 Changed 5 years ago by wiktorn

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 Changed 5 years ago by naoliv

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 Changed 5 years ago by wiktorn

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:

  1. Make sure, that preferences.xml contains commandstack.minimized and commandstack.visible set to true
  2. Run JOSM (-Xmx512m)
  3. Create new layer
  4. Make a dozen of ways, with a lot of nodes, to get ~500 actions in command stack
  5. Verify RES size of application (if it is greater than 512m)
  6. 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 Changed 5 years ago by naoliv

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 Changed 5 years ago by naoliv

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 Changed 5 years ago by stoecker

Could you please provide the minimum config your tried the test with. Sometimes little details are overlooked in descriptions.

comment:15 Changed 5 years ago by naoliv

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='{&quot;X-VE-Tile-Info&quot;:&quot;no-tile&quot;}'/>
      <tag key='metadataHeaders' value='{&quot;X-VE-TILEMETA-CaptureDatesRange&quot;:&quot;Capture Date&quot;}'/>
    </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='{&quot;ETag&quot;:&quot;.*?:OC4CjEZcEJv8Az5u7fOqgEP\\+NpkA\&quot;&quot;}'/>
    </map>
    <map>
      <tag key='name' value='OpenStreetMap (Mapnik Branco &amp; 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='{&quot;ETag&quot;:&quot;\&quot;067736a547cafe90014b4e59b6510abe\&quot;&quot;}'/>
    </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.

Last edited 5 years ago by naoliv (previous) (diff)

comment:16 Changed 5 years ago by wiktorn

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.

Changed 5 years ago by wiktorn

Attachment: hs_err_pid3394.log added

hs_err* file generated on debian/unstable

comment:17 Changed 5 years ago by wiktorn

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:18 Changed 5 years ago by bastiK

Oh, what fun, "write once, debug everywhere".

comment:19 in reply to:  18 Changed 5 years ago by wiktorn

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 Changed 5 years ago by Don-vip

Milestone: 15.11

comment:21 Changed 5 years ago by wiktorn

Resolution: othersoftware
Status: newclosed

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

Modify Ticket

Change Properties
Set your email in Preferences
Action
as closed The owner will remain team.
as The resolution will be set.
The resolution will be deleted.

Add Comment


E-mail address and name can be saved in the Preferences.

 
Note: See TracTickets for help on using tickets.