连接到远程主机不起作用

时间:2012-11-28 10:21:42

标签: php

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

    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文件中删除旧密码标记**

1 个答案:

答案 0 :(得分:3)

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

来自MySQL docs:

  

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

     

MySQL服务器消失的最常见原因是服务器超时并关闭了连接。

修改

您的主机仍在使用旧的MySQL密码方案。如果您可以访问MySQL,则可以根据建议的错误更新密码:

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

UserHost替换为您的详细信息。有关此question的更多信息。