我刚刚在开发机器上更新了我的 Apache 和 PHP 版本,而 PDO 已经完全崩溃了。
这是死的简单 PDO 类:
class PDO_DBH {
public static function openSesame() {
echo '<p>start openSesame: </p>'.microtime(true);
$db_username = 'root';
$db_password = 'pass';
try {
$dbh = new PDO('mysql:host=localhost;dbname=DB_NAME', $db_username, $db_password);
$dbh->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
echo '<p>end successful openSesame: </p>'.microtime(true);
return $dbh;
} catch (PDOException $e) {
echo '<p>end failed openSesame: </p>'.microtime(true);
return 'PDO database access error!';
}
}
}
在升级之前,目前在其他开发机器上,一个典型的页面将在一秒钟内加载,最多两个。
现在,通过 的奇迹microtime(true)
,我看到每个连接打开都需要大约一整秒。
一个典型的页面可能会创建一个新页面$dbh
,然后创建$dbh = null;
20 次,因为不同的对象和方法会检索它们需要的数据。这在其他机器或我的虚拟主机上从来都不是问题。
我在这里哪里出错了?