作者:_路過蓅颩_ | 来源:互联网 | 2024-10-16 16:30
原标题:更改Mysql数据目录,这个坑你可能也趟过~
背景:上周网盘服务器由于要导入一个测试数据库的表。默认的mysql路径硬盘空间太小,而需要导入的测试数据很大。所以需要迁移mysql的data路径。

迁移过程主要有以下几步:
关闭mysql服务→更改/etc/my.cnf下datadir字段的值改为新的目录→将现有data目录下所有文件复制到新的目录下→启动mysql。

但是启动完了后,会报PDO连接数据库失败的错。于是把具体错误打印出来,具体错误原因是:
SQLSTATE[HY000] [2002] No such file or directory
于是到网上查了下问题原因:
出现这个问题的原因是PDO无法找到或者mysqld.sock:由于更改了mysqldata路径,也更改了mysqld.sock的路径,php.ini中默认的socket路径为空时,会找mysql默认的sock,发现已经找不到了,所以会报连接错误。
解决方法
1:找到相应的.sock文件,并设置php.ini文件中的pdo_mysql.default_socket的值为.sock文件的路径。

pdo_mysql.default_socket=/tmp/mysqld.sock
然后重启Apache,或者nginx下重启php-fpm即可。
解决方法2:(我是用这种方法解决,简单省力)
将PDO连接中的dsn的host由“localhost”改为“127.0.0.1”即可

按照第二种办法,将localhost修改为127.0.0.1后,再次连接数据库,就可以连上了。返回搜狐,查看更多
责任编辑: