mysql迁移数据目录,这个坑你遇到过吗?

38 篇文章 1 订阅

mysql数据库在存储过程中,随着存储数据越来越多,有时会遇到存储的磁盘空间不足的情况,于是需要更换存储路径。

迁移过程主要有以下几步:
1、关闭mysql服务;
2、更改/etc/my.cnf下datadir字段的值改为新的目录;
3、将现有data目录下所有文件复制到新的目录下;
4、启动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”即可‍

<?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();
}
?>

mysql迁移数据目录,这个坑你遇到过吗? : https://mp.weixin.qq.com/s/MGuTITqqbuMfCl74fucQ_Q

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值