Can't connect to local MySQL server through socket


mysql -uroot
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)

這是mysql登錄時找不到套接字的問題。

首先需要明白的是,Linux端的mysql server啟動時會開啟一個socket,Linux上的MySQL的客戶端在不使用IP連接時mysql server時,默認也會通過套接字來鏈接mysql server。

1.mysql server的套接字文件。

如果不手動配置my.cnf,那么默認的socket一般是DATADIR/mysql.sock,而DATADIR如果沒有手動修改,一般默認是/var/lib/mysql目錄。不同的mysql版本,可能socket的默認路徑是/tmp/mysql.sock。

例如我將socket路徑修改為/data/mysql.sock

2.客戶端連接時使用的套接字文件。

在Linux上的各種mysql類客戶端(例如mysql,mysqladmin,mysqldump,mysqlimport等)連接mysql server時,如果指定的主機名是'localhost',則會使用套接字來連接mysql server。因此,必須為這些客戶端指定正確的套接字。

方法一:在連接命令行上使用"-S"選項指定

mysqladmin -S /data/mysql.sock
mysql -S /data/mysql.sock
mysqldump -S /data/mysql.sock

方法二:在配置文件中指定
例如在my.cnf中:

[client]
socket=/data/mysql.sock

client段的配置表示任何客戶端連接mysql server時都使用該段配置。因此,這樣配置后,無論是mysql、mysqldump、mysqladmin還是其他的客戶端都會使用socket=/data/mysql.sock進行連接。

除了使用[client]指定全局客戶端的連接參數,還可以為特定的客戶端指定連接參數。例如下面為mysql、mysqldump、mysqladmin這3個客戶端分別指定socket連接參數。

[mysql]
socket=/data/mysql.sock

[mysqldump]
socket=/data/mysql.sock

[mysqladmin]
socket=/data/mysql.sock

注意:如果使用IP,例如mysql -uroot -h'192.168.100.10'則表示使用TCP/IP協議連接mysql,這時不會使用套接字,就沒有套接字找不到的問題。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM