网站突然报错:
Can't connect to local MySQL server through socket '/tmp/mysql.sock'
Can't connect to local MySQL server through socket '/tmp/mysql.sock'
Active UNIX domain sockets
也就是只有你的守护进程启动起来这个文件才存在。
但是你的mysql程序(这个程序是客户端,服务器端是mysqld)可以选择是否使用mysql.sock文件来连接(因为这个方法只适合在Unix主机上面连接本地的mysqld),对于非本地的任何类型的主机。这些在MySQL的手册(包括晏子翻译的中文版本,覆盖3.23/4.0版本)都有说明。只要看看就可以明白。
前面朋友说不能连接,最大可能就是mysqld的这个守护进程没有启动。
哦,我说当时用PDO形式连接数据库的方式,是正常的。用普通的mysql_connect()就有问题。
解决办法:
第一步:mysqld_safe &
第二步(软连接):ln -s /var/lib/mysql/mysql .sock /tmp/mysql .sock
重要参考资料:
http://www.cnblogs.com/super-lucky/p/superlucky.html
http://blog.csdn.net/drecik__/article/details/8456333
http://www.cnblogs.com/wwufengg/articles/mysqld-sock-lost.html
解决方法如下:
Mysql文件mysql.sock丢失丢失的原因一般是因为配置文件不一致的原因,mysqld 错误启动,mysqld_safe 会清除一次mysql.sock 。判断解决故障时没有切换到mysql用户,造成权限有问题,无法创建mysql授权表,所以也就无法创建/tmp/mysql.sock 和hostname.pid文件。
因此,总结解决方法如下:
# /usr/local/bin/mysql_install_db //重建授权表
# /usr/local/bin/mysqld_safe &
# /usr/local/bin/mysql //测试
mysq>bye;
文件已经解决,重新生成新的/tmp/mysql.sock 和 hostname.pid
本文转自许琴 51CTO博客,原文链接:http://blog.51cto.com/xuqin/1400477,如需转载请自行联系原作者