0

我尝试像这样连接到远程主机:

    class Singleton {
  public static $connection;

  public static function getConnection(){
      if(self::$connection==null){
         $dsn = 'mysql:dbname=gtrscrpt_ubot;';
         $user = 'MyUser';
         $password = 'MyPassword';
        try {
           self::$connection = new PDO('mysql:host=gator188.hostgator.com;port=2983;dbname=gtrscpt_ubot;',$user,$password );
           self::$connection->setAttribute( PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
        } catch (PDOException $e) {
            echo 'Connection failed: ' . $e->getMessage();
        }
      }
      return self::$connection;
  }

}


Singleton::getConnection();

我明白了:

Connection failed: SQLSTATE[HY000] [2006] MySQL server has gone away

问题是我不知道我的代码是错误还是无法真正连接到服务器(但我知道我应该连接)

更新: 连接失败:SQLSTATE[HY000] [2000] mysqlnd 无法使用旧的不安全身份验证连接到 MySQL 4.1+。请使用管理工具通过命令 SET PASSWORD = PASSWORD('your_existing_password') 重置密码。这将在 mysql.user 中存储一个新的、更安全的哈希值。如果此用户在 PHP 5.2 或更早版本执行的其他脚本中使用,您可能需要从 my.cnf 文件中删除 old-passwords 标志**

4

1 回答 1

3

看起来你的主机有问题。与他们核实您的主机名、端口和凭据是否正确,并且您的服务器可以访问外部传出网络。

来自MySQL 文档:

C.5.2.9。MySQL 服务器已经消失

MySQL server has gone away 错误最常见的原因是服务器超时并关闭了连接。

编辑:

您的主机仍在使用旧的 MySQL 密码方案。如果您有权访问 MySQL,则可以按照错误提示更新密码:

SET PASSWORD FOR 'User'@'Host'=PASSWORD('yourpassword');
FLUSH Privileges

替换UserHost使用您的详细信息。这个问题的更多信息。

于 2012-11-28T10:30:27.333 回答