1. 程式人生 > >Can't connect to local MySQL server through socket

Can't connect to local MySQL server through socket

through soc 必須 var nec 路徑 localhost ror 通過

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,這時不會使用套接字,就沒有套接字找不到的問題。

Can't connect to local MySQL server through socket