ID:               50111
 Updated by:       datib...@php.net
-Summary:          memory leak when stream_context_create is used
 Reported By:      datib...@php.net
-Status:           Bogus
+Status:           Open
 Bug Type:         Streams related
 Operating System: Linux
 PHP Version:      5.2.11
 New Comment:

I've change the summary a bit to avoid confusion with an actual memory
leak (those that would get reported by php at the end of execution in
debug mode).

When kept running (using cli), an endless loop of given code would
eventually result in an out-of-memory error.

In PHP 5.3.x this no longer happens, so it seems that this has been
rectified before, just not in this branch. It would be nice if the same
fix could be applied here.


Previous Comments:
------------------------------------------------------------------------

[2009-11-09 17:11:31] j...@php.net

Thank you for taking the time to write to us, but this is not
a bug. Please double-check the documentation available at
http://www.php.net/manual/ and the instructions on how to report
a bug at http://bugs.php.net/how-to-report.php



------------------------------------------------------------------------

[2009-11-08 23:27:05] datib...@php.net

Test code changed to (added the unset() statement):

$m0 = $m1 = $i = 0;
$c = null;
while ($i<5) {
    $m0 = memory_get_usage();
    $c = stream_context_create();
    unset($c);
    $m1 = memory_get_usage();
    echo $m1-$m0,PHP_EOL;
    ++$i;
}

Output:
336
420
420
420
420

Though, as a language feature I would assume that in the second
iteration the memory occupied by the previous assignment would be freed
implicitly. Is that a wrong assumption?

------------------------------------------------------------------------

[2009-11-08 21:17:53] srina...@php.net

hmmm.. not sure, why u think there is a leak.

when u write this below code
$c = stream_context_create();

u do understand that underlying php engine need to do some processing 

underneath and store the reference of this processing in $c variable. 
this does require some memory consumption. 

i guess, if u do some thing like and still no
$c = stream_context_create..
unset($c);
$m1 = memory_get_usage();

and still see memory leak , then let us know..

------------------------------------------------------------------------

[2009-11-08 01:06:54] datib...@php.net

Code to reproduce can be made simpler, since the problem seems to be
with stream_context_create():

$m0 = $m1 = $i = 0;
$c = null;
while ($i<5) {
    $m0 = memory_get_usage();
    $c = stream_context_create();
    $m1 = memory_get_usage();
    echo $m1-$m0,PHP_EOL;
    ++$i;
}

------------------------------------------------------------------------

[2009-11-07 09:26:05] datib...@php.net

Description:
------------
When stream_context_create() is used in conjunction with
file_get_contents() or other stream related functions that accept a
context parameter, memory is being leaked.

Reproduce code:
---------------
for ($i=0;$i<5;++$i){
  $m0 = memory_get_usage();
  file_get_contents('http://www.google.com', false,
stream_context_create(array()));
  $m1 = memory_get_usage();
  echo $m1-$m0,PHP_EOL;
}

Expected result:
----------------
X (where X is the memory increase for the first iterator)
0
0
0
0


Actual result:
--------------
X (where X is the memory increase for the first iterator)
384 (or something similar)
420
420
480


------------------------------------------------------------------------


-- 
Edit this bug report at http://bugs.php.net/?id=50111&edit=1

Reply via email to