php.net |  support |  documentation |  report a bug |  advanced search |  search howto |  statistics |  random bug |  login
Bug #70901 PDO memory leak for MySQL
Submitted: 2015-11-12 18:55 UTC Modified: 2017-01-09 05:50 UTC
Votes:3
Avg. Score:5.0 ± 0.0
Reproduced:3 of 3 (100.0%)
Same Version:1 (33.3%)
Same OS:3 (100.0%)
From: nhojohl at gmail dot com Assigned:
Status: Wont fix Package: PDO Core
PHP Version: 5.6.15 OS: Ubuntu 10.04
Private report: No CVE-ID: None
View Developer Edit
Welcome! If you don't have a Git account, you can't do anything here.
If you reported this bug, you can edit this bug over here.
(description)
Block user comment
Status: Assign to:
Package:
Bug Type:
Summary:
From: nhojohl at gmail dot com
New email:
PHP Version: OS:

 

 [2015-11-12 18:55 UTC] nhojohl at gmail dot com
Description:
------------
We have a few extremely long running PHP command line scripts that experience continual  memory usage growth until eventually running out of memory altogether. It took awhile to narrow down the cause, but I believe there's a memory leak in the PDO connection creation process for the MySQL driver.

If you create a connection, any attempt to destroy it will still leave you with a memory usage growth of ~900 bytes.

php -m
[PHP Modules]
bcmath
bz2
calendar
Core
ctype
curl
date
dba
dom
ereg
exif
fileinfo
filter
ftp
gd
gettext
hash
iconv
imagick
json
libxml
mbstring
memcached
mhash
mysql
mysqli
mysqlnd
newrelic
openssl
pcntl
pcre
PDO
pdo_mysql
Phar
posix
pthreads
readline
Reflection
session
shmop
SimpleXML
soap
sockets
SPL
standard
sysvmsg
sysvsem
sysvshm
tokenizer
wddx
xdebug
xml
xmlreader
xmlwriter
Zend OPcache
zip
zlib

[Zend Modules]
Xdebug
Zend OPcache

Test script:
---------------
<?php
$attributes = array(
    PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
    PDO::ATTR_EMULATE_PREPARES => false,
    PDO::ATTR_TIMEOUT => 30,
    PDO::MYSQL_ATTR_SSL_CA => '/etc/pki/tls/certs/mysql-ssl-ca-cert.pem',
    PDO::MYSQL_ATTR_COMPRESS => true
);
for ($i = 0; $i < 100000; ++$i) {
    $db = null;
    try {
        $db = new PDO('mysql:host=localhost;port=3306;dbname=test;charset=utf8', 'test', 'abc123', $attributes);
    } catch (PDOException $e) {
        echo $e->getMessage();
    }
    $db = null;
    echo memory_get_usage().'/'.memory_get_usage(true)."\n";
}


Expected result:
----------------
Semi-consistent memory usage

Actual result:
--------------
Memory usage continually grows

229016/262144
229912/262144
230808/262144
231704/262144
232664/262144
233560/262144
234456/262144
235352/262144
236248/262144
237144/262144
238064/262144
238960/262144
239984/262144
240880/262144
241800/262144
242696/262144
243592/262144
244512/262144
245408/262144
246304/262144
247224/262144
248120/262144
249016/262144
249920/262144
250816/262144
251712/524288
252632/524288
253528/524288
254680/524288
255576/524288
256472/524288
257368/524288
258288/524288
259184/524288
260080/524288
....

Patches

Pull Requests

Pull requests:

History

AllCommentsChangesGit/SVN commitsRelated reports
 [2015-11-15 09:24 UTC] nhojohl at gmail dot com
This appears to occur, not just with MySQL but, with all PDO drivers with the exception of sqlite.
 [2015-11-15 19:39 UTC] nhojohl at gmail dot com
After further testing it appears the PDO's destructor isn't always called - occurs with every PDO driver, including SQLite.

Another simple example:

1. Create a directory named "test.sqlite"

2. Run the following test script in the directory that contains the test.sqlite directory

----

<?php
for ($i = 0; $i < 100000; ++$i) {
    $db = null;
    try {
        $db = new PDO('sqlite:test.sqlite');
    } catch (PDOException $e) {
        echo $e->getMessage();
    }
    $db = null;
    echo memory_get_usage().'/'.memory_get_usage(true)."\n";
}

----

3. You should get an exception for "SQLSTATE[HY000] [14] unable to open database file" and continually increasing memory usage - `dbh_free` in `php-src/ext/pdo/pdo_dbh.c` will not be called until the script exits. It should be called when the exception occurs and `new PDO` returns null.

I've submitted a pull request that resolves the issue.
 [2015-11-16 00:25 UTC] nhojohl at gmail dot com
-Package: PDO MySQL +Package: PDO Core
 [2015-11-16 00:25 UTC] nhojohl at gmail dot com
Changed affected package
 [2017-01-09 05:50 UTC] krakjoe@php.net
-Status: Open +Status: Wont fix
 [2017-01-09 05:50 UTC] krakjoe@php.net
Changes were requested on github more than a year ago, since no changes came, the pull request was closed.
 
PHP Copyright © 2001-2024 The PHP Group
All rights reserved.
Last updated: Thu Dec 26 15:01:32 2024 UTC