Getting Rich with PHP 5 |
data:image/s3,"s3://crabby-images/df4e9/df4e9fe87e5ae6090786f78eb8aeccaa35a0f8b3" alt="" |
2025-02-23 |
data:image/s3,"s3://crabby-images/4bc81/4bc81c0e701268b0151eda1b01bcf94b5b516447" alt="" |
data:image/s3,"s3://crabby-images/ff17d/ff17d39ab60eb6d9168040e5a4c42b701a2a0f95" alt="" |
data:image/s3,"s3://crabby-images/4bc81/4bc81c0e701268b0151eda1b01bcf94b5b516447" alt=""
7 |
data:image/s3,"s3://crabby-images/3b139/3b13919dac11ade026e709fd8f417c0b20fb3fc3" alt="" |
data:image/s3,"s3://crabby-images/4bc81/4bc81c0e701268b0151eda1b01bcf94b5b516447" alt="" |
Non-persistent: 370 requests/second
Persistent: 525 requests/second
This is with MySQL's query cache enabled. But Callgrind shows us that we are actually
calling MySQL's internal prepare/execute API.
Callgraph [mysql.out]
Use direct queries
<?php
$config = array(
'db' => 'mysql',
'db_user' => 'nobody',
'db_pwd' => 'foobar',
'db_host' => 'localhost',
'db_db' => 'users',
'db_opts' => array(PDO::ERRMODE_EXCEPTION => true,
PDO::ATTR_PERSISTENT => true,
PDO::ATTR_EMULATE_PREPARES=>true)
);
?>
PDO::ATTR_EMULATE_PREPARES was added in PHP 5.1.3. You can use PDO::MYSQL_ATTR_DIRECT_QUERY in earlier versions.
That brings us to 580 requests/second. Down to 3 servers!
The same tests with InnoDB reveal similar numbers.
Sqlite3 comes in at around 550 requests/second with persistent connections.