0

PHP mysql_connect 有时由于“连接太多”而失败。在检查进程状态列表时,我注意到当这种情况发生时,有很长的进程处于睡眠状态。多久?时间:28490

这就是我初始化连接的方式:

            $this->connection[$server] = mysql_connect( $credentials['dbUrl'], $credentials['dbUser'], $credentials['dbPass'], true);

这不会一直发生,只是有时连接会“卡住”。我认为这可能与页面上的某些内容未完成有关(图像未加载?外部服务卡住?)。剧本什么时候正式完成?是在页面完全加载之后吗?

我想到了两种可能的解决方案: 1. 使用 mysql_close。2. 更改最大 mysql 超时 ( /etc/my.cnf) 3. 处理脚本超时。

什么原因会导致连接陷入“睡眠”?您建议如何解决/进一步调查该问题?

4

1 回答 1

1

一个很好的解决方案是将您的连接放入一个函数中,然后添加一个析构函数来为您关闭连接。这样连接会在最后一次调用 mysql 连接后自动关闭。

class DbConn {
    public $connection;

    public function __construct($host, $name, $user, &$pass) {
        $this->connection = mysql_connect(mysql_connect($host, $user, $pass);
        if(mysql_connect_errno) {
            echo mysql_connect_error;
        } else {
            mysql_select_db($name, $this->connection);
        }
        unset($pass); //Clear password for security.
    }

    public function __destruct() {
        mysql_close($this->connection);
    }
}

这应该照顾大多数打开的连接,因为它们将在脚本结束之前关闭,即使脚本挂在图像上,连接也会在最后一个查询运行后关闭。您可能仍然会得到一些,但不足以导致too many connections错误。

于 2013-07-03T14:53:10.533 回答