ID: 48343
Updated by: [email protected]
Reported By: mikec at mikenz dot geek dot nz
-Status: Open
+Status: Bogus
Bug Type: MySQLi related
Operating System: *
PHP Version: 5.3CVS-2009-05-20 (snap)
New Comment:
Yes the memory calculation is now more precise and mysqlnd uses some
own caching so it will re use some of the memory on your next query.
Previous Comments:
------------------------------------------------------------------------
[2009-05-21 13:02:49] mikec at mikenz dot geek dot nz
Most of the memory is available again once it is destroyed. Very
similar between both versions.
The problem is that code which loops over large number of rows in php
5.2 with near constant memory usage now increase in memory usage as
it loops through the rows in 5.3 causing termination when they hit
the memory limit. Reported memory usage for a script in php 5.3 is a
lot higher than in php 5.2.
This bug may be bogus as mysqlnd uses php memory allocation so its
memory usage is now included in memory usage checks where libmysql's
memory usage in 5.2 was independent and uncounted. Can a developer
confirm? If so this should be noted in the PHP 5.3 upgrading notes or
migration information as it is unexpected at the moment.
------------------------------------------------------------------------
[2009-05-21 11:36:58] ninzya at inbox dot lv
Try destroying mysqli object before calculating estimated memory usage.
See what are results.
------------------------------------------------------------------------
[2009-05-20 05:56:05] mikec at mikenz dot geek dot nz
Description:
------------
A simple loop fetching rows from a database uses a lot more memory of
php5.3 when compared to php5.2.
First noticed on a Debian machine. Confirmed on a Windows machine with
latest snaps (20-May-2009). php.ini based on php.ini-dist/development
only change is to enable mysqli.
Reproduce code:
---------------
<?php
/**
Mysql test table:
CREATE TABLE `test` (
`id` int(11) NOT NULL auto_increment,
`value` int(11) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1;
INSERT INTO `test` VALUES (1, 910044366),(2, 598209383),(3,
1057704306),(4, 877739287),(5, 260395243),(6, 1154353180),(7,
19390630),(8, 362285832),(9, 510459913),(10, 222644712),(11,
824641253),(12, 969677378),(13, 1131665776),(14, 263701992),(15,
409107462);
*/
$before = memory_get_usage();
echo "Memory Usage (in bytes)";
echo "\nBefore: " . $before;
$db = new mysqli("127.0.0.1", "test", "testpasswd", "test");
$result = $db->query('SELECT * FROM `test`');
$rows = 0;
while($result->fetch_array(MYSQLI_ASSOC)) {$rows++;}
$after = memory_get_usage();
echo "\nAfter: " . $after;
echo "\nDelta: " . ($after - $before);
echo "\nDelta per row: " . round(($after - $before)/$rows) . ' bytes
per row';
Expected result:
----------------
C:\test\php-5.2-nts-win32-VC6-x86-latest>php -v
PHP 5.2.10-dev (cli) (built: May 19 2009 11:46:39)
Copyright (c) 1997-2009 The PHP Group
Zend Engine v2.2.0, Copyright (c) 1998-2009 Zend Technologies
C:\test\php-5.2-nts-win32-VC6-x86-latest>php r:\dbmem.php
Memory Usage (in bytes)
Before: 55216
After: 56080
Delta: 864
Delta per row: 58 bytes per row
Actual result:
--------------
C:\test\php-5.3-nts-win32-VC9-x86-latest>php -v
PHP 5.3.0RC3-dev (cli) (built: May 19 2009 12:57:00)
Copyright (c) 1997-2009 The PHP Group
Zend Engine v2.3.0, Copyright (c) 1998-2009 Zend Technologies
C:\test\php-5.3-nts-win32-VC9-x86-latest>php r:\dbmem.php
Memory Usage (in bytes)
Before: 321328
After: 337384
Delta: 16056
Delta per row: 1070 bytes per row
Would expect the Delta per row to be the similar for PHP 5.3 but this
is
no where near.
------------------------------------------------------------------------
--
Edit this bug report at http://bugs.php.net/?id=48343&edit=1