我尝试连接到这样的远程主机:
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文件中删除旧密码标记**
答案 0 :(得分:3)
您的主机看起来有问题。与他们核实您的主机名,端口和凭据是否正确,以及您的服务器是否可以访问外部传出网络。
<强> C.5.2.9。 MySQL服务器已经消失
MySQL服务器消失的最常见原因是服务器超时并关闭了连接。
修改强>
您的主机仍在使用旧的MySQL密码方案。如果您可以访问MySQL,则可以根据建议的错误更新密码:
SET PASSWORD FOR 'User'@'Host'=PASSWORD('yourpassword');
FLUSH Privileges
将User
和Host
替换为您的详细信息。有关此question的更多信息。