這是mysql登錄時找不到套接字的問題。 首先需要明白的是,Linux端的mysql server啟動時會開啟一個socket,Linux上的MySQL的客戶端在不使用IP連接時mysql server時,預設也會通過套接字來鏈接mysql server。 1.mysql server的套接字文件。 ...
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,這時不會使用套接字,就沒有套接字找不到的問題。