PDO连接数据库报错:“
SQLSTATE[HY000] [2002] No such file or directory”。
然后重启Apache,或者nginx下重启php-fpm即可。
参考:http://stackoverflow.com/questions/20723803/pdoexception-sqlstatehy000-2002-no-such-file-or-directory/22927341#22927341
出现这个问题的原因是PDO无法找到MySQL.sock或者mysqld.sock。
解决方法1:找到相应的.sock文件,并设置PHP.ini文件中的pdo_mysql.default_socket的值为.sock文件的路径。
- pdo_mysql.default_socket= /tmp/mysqld.sock
解决方法2:(我是用这种方法解决,简单省力)
将PDO连接中的dsn的host由“localhost”改为“127.0.0.1”即可
- <?php
- header("Content-Type=text/html;charset=utf8");
- $dbType = 'mysql';
- $host = '127.0.0.1'; //此处不用localhost
- $dbName = 'joe';
- $userName = 'root';
- $pwd = '';
- $dsn = "$dbType:host=$host;dbname=$dbName";
- try {
- $pdo = new PDO($dsn, $userName, $pwd);
- echo '连接成功';
- } catch (PDOException $e) {
- echo '连接失败:' . $e->getMessage();
- }
- ?>