解決 Can’t connect to local mysql server through socket ‘/tmp/mysql.sock’ (2) |#2002
我安裝的是lnmp0.7一鍵安裝包,之前一直正常使用??墒墙袢罩貑⒘艘幌耼ginx后,奇怪的問題出現了:
Discuz X2出來錯誤:
[Type] 無法連接到數據庫服務器[2002] Can’t connect to local MySQL server through socket ‘/tmp/mysql.sock‘ (2)或是這個錯誤(Can’t connect to local MySQL server through socket ‘/var/lib/mysql/mysql.sock’ (2))
phpMyAdmin也無法用root登陸
#2002 無法登錄 MySQL 服務器
找了一下/tmp/也找不到mysql.sock
解決方法:
1、 登陸ssh,使用以下命令
ps -aux|grep mysql
2、 然后結束你看到的pid
kill pid
(如,我的話就是要運行kill 17874;kill 17987;kill 30579;)
3、 最后重啟mysql
/etc/rc.d/init.d/mysql restart
或者
service mysql restart
嘿嘿,成功了!/tmp/mysql.sock出現了!
如果你的情況跟我的不一樣可以參考以下文章:
解決方法:php標準配置正是通過’/tmp/mysql.sock’,但一些mysql安裝方法將mysql.sock放在/var/lib/mysql.sock或者其他地方,你可以通過修改/etc/my.cnf文件來修正它,打開文件
更改一下:
[mysqld] socket=/var/lib/mysql.sock 假如更改后mysql程序連不上,可以使用下面的方法繼續修改:[mysql] socket=/tmp/mysql.sock
另外還可以用下面的方法:
ln -s /var/lib/mysql/mysql.sock /tmp/mysql.sock
Can not connect to local MySQL server through socket 解決辦法
尋找 mysql.sock文件
find / -name mysql.sock
1. 先查看 /etc/rc.d/init.d/mysqld status 看看mysql是否已經啟動,另外看看是不是權限問題。
2. 確定你的mysql.sock是不是在那個位置
mysql -u 你的mysql用戶名 -p -S /var/lib/mysql/mysql.sock
3、試試
service mysqld start
4、如果是權限問題,則先改變權限
chown -R mysql:mysql /var/lib/mysql/etc/init.d/mysqld start
相關文章:
