記錄一個mysql連線慢的問題

軒脈刃發表於2016-05-17

問題現象是這樣的:

我在一臺機器上(61.183.23.23)啟動了一個mysql,然後開通一個賬號可以從127.0.0.1或者從61.183.23.23訪問。但是遇到一個問題就是使用下面兩個命令列訪問的時候,速度差別非常大:

mysql –h 127.0.0.1 –u user

mysql –h 61.183.23.23 –u user

 

然後我使用ping,判斷兩個IP的速度差不多。

使用127.0.0.1的IP速度比另一個快太多了。雖然說這裡的61.183.23.23需要去外網走一圈,但是速度差別怎麼會差這麼多。

 

解決辦法:

mysql使用skip-name-resolve禁止掉DNS的查詢。

mysql會在使用者登入過程中對客戶端IP進行DNS反查,不管你是使用IP登入還是域名登入,這個反查的過程都是在的。所以如果你的mysql所在的伺服器的DNS有問題或者質量不好,那麼就有可能造成我遇到的這個問題,DNS解析出現問題。

修改mysql配置檔案

[mysqld]

skip-name-resolve

 

補充:

做個提醒,增加skip-name-resolve有可能導致賬號失效,比如我原先的賬號是yejianfeng@localhost,然後其實我使用mysql -h127.0.0.1 -uyejianfeng 是可以登入的。但是一旦加上了skip-name-resolve,就不能登入的了。需要加上賬號yejianfeng@127.0.0.1


相關文章