天天看點

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

作者:駿馬金龍

出處: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