欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql登錄時報socket找不到的問題及解決

 更新時間:2024年07月16日 11:01:01   作者:我是李超人  
這篇文章主要介紹了mysql登錄時報socket找不到的問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

mysql登錄時報socket找不到

mysqld.socket文件是用來給客戶端和服務(wù)端進行通信的,如果通過源碼方式安裝,默認情況下這個文件會被放在tmp目錄下。

當然也可以手動指定存放位置,通過修改/etc/my.cnf文件的socket參數(shù)來修改mysqld.socket的存放路徑。

例如:

[mysqld]
socket=/data/mysqldb/mysqld.sock

但是這樣一來在登錄的時候就會出現(xiàn)如下問題

[root@s186 /data/mysql]#/usr/local/mysql/bin/mysql -uroot -p
Enter password: 
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)

mysql客戶端在登錄的時候默認會去/tmp/mysql.sock這個目錄查找mysqld.socket文件,由于修改了路徑自然是找不到的。

可以通過修改/etc/my.cnf文件給客戶端指定位置。

添加如下配置:

[client]
socket=/data/mysqldb/mysqld.sock

這樣客戶端在登錄時就會去指定的目錄查找mysqld.socket文件,

注意client的socket要和mysqld是一樣的,因為客戶端和服務(wù)端通信靠的就是這個文件,肯定要一致

通過上面的案例應(yīng)該明白為何服務(wù)端可以啟動,但是登錄的時候會報socket找不到的問題了。

出現(xiàn)socket找不到的問題大致有以下幾種情況

1.mysqld和client的socket配置路徑不一樣

比如像下面這樣的配置

[mysqld]
socket=/data/mysqldb/mysqld.sock
[client]
socket=/data/mysqldb/mysql.sock

路徑是一樣的,但是文件名不一樣,一個是mysqld.socket,一個是mysql.socket

socket文件是由服務(wù)端生成的,而客戶端找的就是服務(wù)端生成的socket文件,所以client的配置要和mysqld一樣

2.在cmake的時候指定了路徑

比如像下面這一段cmake指令

在參數(shù)DMYSQL_UNIX_ADDR=/tmp/mysqld.sock中指定了socket的位置

那么/etc/my.cnf上mysqld上的socket和client上的socket都需要和這個一致

因為cmake在執(zhí)行完之后,mysqld這個執(zhí)行文件才會生成,并且這個執(zhí)行文件中會記錄你指定的參數(shù)

那么當執(zhí)行mysqld的時候,它就會在你指定的目錄下去查找

這個時候/etc/my.cnf下的mysqld和client的socket必須和指定的路徑保持一致

否則mysqld執(zhí)行都會失?。〞骳hange dir…這樣的錯誤)

cmake \-DCMAKE_INSTALL_PREFIX=/usr/local/mysql56 -DMYSQL_DATADIR=/data/mysqldb/data -DSYSCONFDIR=/etc/my.cnf  -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_MEMORY_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DMYSQL_UNIX_ADDR=/data/mysqld.sock -DMYSQL_TCP_PORT=3306 -DENABLED_LOCAL_INFILE=1 -DWITH_PARTITION_STORAGE_ENGINE=1 -DEXTRA_CHARSETS=utf8 -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci

解決方法

解決socket的核心就是在登錄的時候告訴客戶端socket文件的位置

要么通過/etc/my.cnf文件指定位置

要么就是在登錄的時候指定位置

像下面這樣:

mysql -uroot -p --socket=/data/mysqldb/mysqld.sock

還有一種方式就是創(chuàng)建軟連接,因為客戶端默認會到/tmp下找mysqld.socket文件

我不通過配置文件,在tmp下建一個軟連接就可以了

ln -s /data/mysqldb/mysqld.sock mysql.socket

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 運維角度淺談MySQL數(shù)據(jù)庫優(yōu)化(李振良)

    運維角度淺談MySQL數(shù)據(jù)庫優(yōu)化(李振良)

    一個成熟的數(shù)據(jù)庫架構(gòu)并不是一開始設(shè)計就具備高可用、高伸縮等特性的,它是隨著用戶量的增加,基礎(chǔ)架構(gòu)才逐漸完善。這篇博文主要談MySQL數(shù)據(jù)庫發(fā)展周期中所面臨的問題及優(yōu)化方案
    2015-07-07
  • MYSQL大量寫入問題優(yōu)化詳解

    MYSQL大量寫入問題優(yōu)化詳解

    這篇文章主要介紹了MYSQL大量寫入問題優(yōu)化詳解,文中優(yōu)化點解釋的很清楚,讓人看完就明了,感興趣的同學(xué)可以閱讀理解下
    2021-03-03
  • mysql的啟動過程詳解

    mysql的啟動過程詳解

    這篇文章主要介紹了mysql的啟動過程詳解,本文用生動風(fēng)趣的文風(fēng)講解了mysql的啟動過程,絕對讓你難忘哦,需要的朋友可以參考下
    2014-08-08
  • 最新評論