<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
  <meta content="text/html;charset=UTF-8" http-equiv="Content-Type">
</head>
<body bgcolor="#ffffff" text="#000000">
My solution to this problem (only for ie) was to reload the whole page
after a number of layer refreshes, because apparently IE doesn't free
the used objects untill the page is reloaded...<br>
<br>
<br>
Kris Geusebroek wrote:
<blockquote
 cite="mid:F1CD93776CC6A645B83FB3C8B82971F201C5A196@xebia-exchange.hosted.xebia.com"
 type="cite">
  <pre wrap="">Hi Hendrik,

A few months ago i posted a partial solution to this list.
Original mail is attached.

Hope this helps. If you make any improvements on this solution please let me know I'm still very interested in this topic.

Cheers Kris

-----Original Message-----
From: <a class="moz-txt-link-abbreviated" href="mailto:users-bounces@openlayers.org">users-bounces@openlayers.org</a> [<a class="moz-txt-link-freetext" href="mailto:users-bounces@openlayers.org">mailto:users-bounces@openlayers.org</a>] On Behalf Of Hendrik Nibbrig
Sent: Thursday, September 03, 2009 9:43 AM
To: <a class="moz-txt-link-abbreviated" href="mailto:users@openlayers.org">users@openlayers.org</a>
Subject: [OpenLayers-Users] Need help with memory leak in IE

 
Hi,

My name is Hendrik and I'm currently evaluating OSM with OpenLayers to see if this is the way to go for our company. I have been developing in C++ and Java for the last 5 years to please go easy on me with Javascript as this is new to me. 

Our application will be displaying a list of vehicles on one side of the screen and then the user can pick one. We will then show the route of the vehicle on the map (e.g. using markers) along with a heap of other information. The Javascript will do a refresh every minute and so the map will be updated every minute as well. The user is free to switch to another vehicle at any time so I need to delete all current markers and then insert the new ones.

The current map system (by Infoware) has lots of issues which is why we want to change to OSM and OpenLayers. Therefore I made a little showcase where I can run some tests. The tests have showed that everything is fine using Firefox but in IE the memory steadily increases. IE7 is tolerable, but IE8 will be unbearable. 
I attached the showcase so you can have a look at the sourcecode. The data is anonym so don't worry about that. The best test to run is "Show whole trip every 5 seconds". This will insert 500 markers every 5 seconds and it will clear the existing markers before. As you can see in the showcase I tried using a vector as well but that wasn't any better. I'm open to any suggestions or even better solutions :)  

Oh btw: Except for the memory problem (which might be an issue of IE itself) I think OpenLayers is a great tool and on the right way.

Sorry if this gets double posted, but the first post was too large and I couldn't cancel it.

Kind regards/Mit freundlichen Gr��en

Hendrik Nibbrig
Systemanalytiker Java




T +49. 3375. 528 30 204

F +49. 3375. 528 30 19

<a class="moz-txt-link-abbreviated" href="mailto:hendrik.nibbrig@enovation-btc.de">hendrik.nibbrig@enovation-btc.de</a>  �  <a class="moz-txt-link-abbreviated" href="http://www.enovation-btc.de">www.enovation-btc.de</a> 

 

E.Novation BTC GmbH   

Freiheitstra�e 120 B  �  15745 Wildau

Managing Director: Walther Bernard
Registered Court: Amtsgericht Potsdam HRB 12345



This E-Mail may contain confidential and/or privileged information. If you are not the intended recipient (or have received this E-Mail in error) please notify the sender immediately and destroy this email. Any unauthorized copying, disclosure or distribution of the material in this email is strictly forbidden.
  </pre>
  <br>
  <hr size="4" width="90%"><br>
  <table class="header-part1" border="0" cellpadding="0" cellspacing="0"
 width="100%">
    <tbody>
      <tr>
        <td>
        <div class="headerdisplayname" style="display: inline;">Subject:
        </div>
Re: [OpenLayers-Dev] [OpenLayers-Users] Performance and
Memoryusagemeasuring: How To</td>
      </tr>
      <tr>
        <td>
        <div class="headerdisplayname" style="display: inline;">From: </div>
"Kris Geusebroek" <a class="moz-txt-link-rfc2396E" href="mailto:kgeusebroek@xebia.com">&lt;kgeusebroek@xebia.com&gt;</a></td>
      </tr>
      <tr>
        <td>
        <div class="headerdisplayname" style="display: inline;">Date: </div>
Thu, 14 May 2009 09:48:45 +0200</td>
      </tr>
      <tr>
        <td>
        <div class="headerdisplayname" style="display: inline;">To: </div>
<a class="moz-txt-link-rfc2396E" href="mailto:peter@peterse-uithuizen.com">&lt;peter@peterse-uithuizen.com&gt;</a>, "OpenLayers mailinglijst"
<a class="moz-txt-link-rfc2396E" href="mailto:users@openlayers.org">&lt;users@openlayers.org&gt;</a>, <a class="moz-txt-link-rfc2396E" href="mailto:dev@openlayers.org">&lt;dev@openlayers.org&gt;</a></td>
      </tr>
    </tbody>
  </table>
  <table class="header-part2" border="0" cellpadding="0" cellspacing="0"
 width="100%">
    <tbody>
      <tr>
        <td>
        <div class="headerdisplayname" style="display: inline;">To: </div>
<a class="moz-txt-link-rfc2396E" href="mailto:peter@peterse-uithuizen.com">&lt;peter@peterse-uithuizen.com&gt;</a>, "OpenLayers mailinglijst"
<a class="moz-txt-link-rfc2396E" href="mailto:users@openlayers.org">&lt;users@openlayers.org&gt;</a>, <a class="moz-txt-link-rfc2396E" href="mailto:dev@openlayers.org">&lt;dev@openlayers.org&gt;</a></td>
      </tr>
    </tbody>
  </table>
  <br>
  <pre wrap="">Hi all,

Sadly i didn't get any replies on this mail so I investigated further
myself and found a partial solution.
It seems that IE leaves a reference to the element which is removed with
the removeChild method.

Since this method is heavily used in OpenLayers refreshing a layer often
will add Dom elements to the memory all the time.

I created a patch to replace the removeChild method (at least the cases
where an element can be removed really) by a utility method which really
removes an element.

I attached a patch file to this email for those who are in need of a
solution.
Still there's a small amount of memory added on every refresh (talking
about 40-100 kB every refresh) which I'm not able to pinpoint.

QUESTION: is there any tool which I can use to inspect the memory and
see which elements are using memory??

Cheers Kris

-----Original Message-----
From: <a class="moz-txt-link-abbreviated" href="mailto:users-bounces@openlayers.org">users-bounces@openlayers.org</a> [<a class="moz-txt-link-freetext" href="mailto:users-bounces@openlayers.org">mailto:users-bounces@openlayers.org</a>]
On Behalf Of Kris Geusebroek
Sent: Friday, May 08, 2009 4:14 PM
To: <a class="moz-txt-link-abbreviated" href="mailto:peter@peterse-uithuizen.com">peter@peterse-uithuizen.com</a>; OpenLayers mailinglijst
Subject: Re: [OpenLayers-Users] Performance and Memoryusage measuring:
How To

Hi all,

Ive tied out sIeve to measure leaks and memory usage of my OpenLayers
client and see some strange things.

I have a Vector layer with bbox strategy and wfs protocol that refreshes
every 5 seconds.
I have points wit h labels and some background image/stroke etc.

If I zoom in on 1 feature every refresh 7 dom elements are added to the
#inUse.
If I check the in use elements I can see references to the previous id's
marked orphan and some not marked orphan (the reason for them is the
removeChild isn't called but they are mostly childs of orphan's).

However memory is not freed at all. Memory is only freed as I browse to
other page (<a class="moz-txt-link-freetext" href="about:blank">about:blank</a> for example). But not all of the used memory is
freed.
Also when unloading my client a few (23) leaks are reported but not more
info.

Few questions:
How can I see what the memory is used for? are there other tools to see
memory use of the app.
Should I care about the orphaned dom elements and children of them?
How can I  see what the leaks are about?

Any help Is much appreciated (been banging my head all day now)

Cheers Kris





_______________________________________________
Users mailing list
<a class="moz-txt-link-abbreviated" href="mailto:Users@openlayers.org">Users@openlayers.org</a>
<a class="moz-txt-link-freetext" href="http://openlayers.org/mailman/listinfo/users">http://openlayers.org/mailman/listinfo/users</a>
  </pre>
  <pre wrap=""><pre wrap="">
<hr size="4" width="90%">
_______________________________________________
Users mailing list
<a class="moz-txt-link-abbreviated" href="mailto:Users@openlayers.org">Users@openlayers.org</a>
<a class="moz-txt-link-freetext" href="http://openlayers.org/mailman/listinfo/users">http://openlayers.org/mailman/listinfo/users</a>
</pre></pre>
</blockquote>
<br>
<br>
<pre class="moz-signature" cols="72">-- 
--- 
Adrian Popa
NOC Division
Network Engineer
Divizia Centrul National de Operare Retea
Departament Transport IP &amp; Metro
Compartiment IP Core &amp; Backbone
Phone: +40 21 400 3099
</pre>
</body>
</html>