【问题标题】:Connecting to a distant host doesnt work连接到远程主机不起作用
【发布时间】:2012-11-28 10:21:42
【问题描述】:

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

    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 标志**

【问题讨论】:

    标签: php


    【解决方案1】:

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

    来自MySQL docs:

    C.5.2.9。 MySQL 服务器已消失

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

    编辑:

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

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

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

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2021-08-12
      • 1970-01-01
      • 2016-12-20
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多