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,這時不會使用套接字,就沒有套接字找不到的問題。
作者:駿馬金龍
出處:http://www.cnblogs.com/f-ck-need-u/
Linux運維交流群:921383787
Linux系列文章:https://www.junmajinlong.com/linux/index/
Shell系列文章:https://www.junmajinlong.com/shell/index/
網站架構系列文章:http://www.cnblogs.com/f-ck-need-u/p/7576137.html
MySQL/MariaDB系列文章:https://www.cnblogs.com/f-ck-need-u/p/7586194.html
Perl系列:https://www.junmajinlong.com/perl/index
Go系列:https://www.cnblogs.com/f-ck-need-u/p/9832538.html
Python系列:https://www.cnblogs.com/f-ck-need-u/p/9832640.html
Ruby系列:https://www.junmajinlong.com/ruby/index
作業系統系列:https://www.junmajinlong.com/os/index/
精通awk系列:https://www.junmajinlong.com/shell/awk/index