解決 Can’t connect to local mysql server through socket ‘/tmp/mysql.sock’ (2) |#2002
我安裝的是lnmp0.7一鍵安裝包,之前一直正常使用。可是今日重啟了一下nginx后,奇怪的問題出現(xiàn)了:
Discuz X2出來錯(cuò)誤:
[Type] 無法連接到數(shù)據(jù)庫服務(wù)器[2002] Can’t connect to local MySQL server through socket ‘/tmp/mysql.sock‘ (2)或是這個(gè)錯(cuò)誤(Can’t connect to local MySQL server through socket ‘/var/lib/mysql/mysql.sock’ (2))
phpMyAdmin也無法用root登陸
#2002 無法登錄 MySQL 服務(wù)器
找了一下/tmp/也找不到mysql.sock
解決方法:
1、 登陸ssh,使用以下命令
ps -aux|grep mysql
2、 然后結(jié)束你看到的pid
kill pid
(如,我的話就是要運(yùn)行kill 17874;kill 17987;kill 30579;)
3、 最后重啟mysql
/etc/rc.d/init.d/mysql restart
或者
service mysql restart
嘿嘿,成功了!/tmp/mysql.sock出現(xiàn)了!
如果你的情況跟我的不一樣可以參考以下文章:
解決方法:php標(biāo)準(zhǔn)配置正是通過’/tmp/mysql.sock’,但一些mysql安裝方法將mysql.sock放在/var/lib/mysql.sock或者其他地方,你可以通過修改/etc/my.cnf文件來修正它,打開文件
更改一下:
[mysqld] socket=/var/lib/mysql.sock 假如更改后mysql程序連不上,可以使用下面的方法繼續(xù)修改:[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是否已經(jīng)啟動(dòng),另外看看是不是權(quán)限問題。
2. 確定你的mysql.sock是不是在那個(gè)位置
mysql -u 你的mysql用戶名 -p -S /var/lib/mysql/mysql.sock
3、試試
service mysqld start
4、如果是權(quán)限問題,則先改變權(quán)限
chown -R mysql:mysql /var/lib/mysql/etc/init.d/mysqld start
相關(guān)文章:
1. Mybatis查詢方法如何實(shí)現(xiàn)沒有返回值2. MySQL基礎(chǔ)教程9 —— 函數(shù)之日期和時(shí)間函數(shù)3. centos 7安裝mysql5.5和安裝 mariadb使用的命令4. 輕松解決SQL Server 2005中的常見問題5. 數(shù)據(jù)庫人員手冊之ORACLE應(yīng)用源碼6. DB2 XML 全文搜索之為文本搜索做準(zhǔn)備7. mssql鎖基礎(chǔ)教程8. 快速解決mysql導(dǎo)出scv文件亂碼、躥行的問題9. 用SQL SERVER記錄站點(diǎn)日志10. MySQL 千萬級數(shù)據(jù)量如何快速分頁
