1

对于我们自己服务器上的项目,我已经多次使用 PHP 访问 MySQL 数据库,并且总是使用相同的 PHP 脚本来访问(显然更改了登录详细信息)。然而,这是我第一次使用 Heroku 和 ClearDB,我遇到了问题。

该数据库位于我们使用 ClearDB 的 Heroku PHP 应用程序上,我访问了 CLEARDB_DATABASE_URL 以找出用户名、密码、主机名和数据库名称。为了确保我做得正确,我的理解是这是格式:

mysql://USER_NAME:PASSWORD@HOST_NAME/DATABASE_NAME?reconnect=true

在 MySQL Workbench 中使用这些详细信息,我设法登录到数据库并添加了一个表,所以我相信它们是正确的详细信息。

但是,当我尝试使用我的 PHP 脚本访问它时,使用从 URL 获取的相同变量,我收到以下错误:

HTTP Error 500 (Internal Server Error): An unexpected condition was encountered while the server was attempting to fulfill the request.

起初我认为 Heroku 应用程序可能已经完成,但我仍然可以访问 PHP 脚本中不尝试访问数据库的任何函数。

正如我所说,这个脚本以前一直有效,所以我不确定问题出在哪里。我的数据库连接位于具有以下构造函数的单独类中:

function __construct()
{
    $this->DB_HOST     = 'us-cdbr-east-02.cleardb.com';
    $this->DB_USERNAME = 'the_username_from_url';
    $this->DB_PASSWORD = 'the_password_from_url';
    $this->DB_DATABASE = 'the_database_name_from_url';

}

使用其他类根据需要调用的 connect() 函数:

function connect()
{       
    self::$instance = new mysqli($this->DB_HOST, $this->DB_USERNAME, $this->DB_PASSWORD, $this->DB_DATABASE);

    if (mysqli_connect_errno()) {
        $this->raise_error(printf("Connect failed: %s\n", mysqli_connect_error()));
    }

    return self::$instance;
}

我 99.9% 确定问题是由尝试连接到数据库引起的。尽管当我在浏览器中测试脚本时它没有返回任何 PHP 错误消息,但只有基于 DB 的函数会导致 500 错误。

我愿意接受任何和所有的建议......

4

1 回答 1

1

对于那些有同样问题的人,我已经解决了这个问题,但我不是 100% 确定如何,这是 2 种可能的事情之一。首先,我使用自定义 buildpack 重建了我的 Heroku 应用程序。起初这不起作用,所以我认为这不是答案。然后我离开 Heroku 应用程序两周......突然它与 mySQLi 兼容!

自定义 buildpack 可以正常工作并且只需要时间来激活,或者 Heroku 在最后进行了更改,从而解决了我的问题。

抱歉,我无法提供更好的答案,但正如我所说,在离开 Heroku 应用程序大约 2 周后,问题奇迹般地解决了。

于 2012-12-18T17:46:08.287 回答