萬盛學電腦網

 萬盛學電腦網 >> 數據庫 >> mysql教程 >> mysql遠程連接很慢解決辦法

mysql遠程連接很慢解決辦法

mysql遠程連接很慢一般是my.cnf中的skip-name-resolve沒有配置好了,我們只要簡單配置一下就可以了,下面我把我解決辦法分享給各位。

今天由於偶然登錄mysql服務器(mysql服務器裝有phpmyadmin)查看進程(SHOW PROCESSLIST),我了個去,大量未被認證用戶連接mysql,進程結果如下:


|13|unauthenticated user|10.135.26.100:42345|NULL|Connect| |login|NULL|

|14|unauthenticated user|10.135.26.100:42346|NULL|Connect| |login|NULL|

|15|unauthenticated user|10.135.26.100:42349|NULL|Connect| |login|NULL|


 

我了個去,這是蝦米情況呢?問了百度谷歌,原因為: MYSQL開啟了DNS的反向解析,貌似默認安裝就會出現這東東。問題找到,自然問題也就迎刃而解。


1.在啟動參數中添加--skip-name-resolve,關閉反向域名解析功能
2.在my.cnf的[mysqld]一節中增加skip-name-resolve
3.在/etc/hosts文件中添加對應的host記錄
為方便起見,直接采用方案2,在mysql配置文件my.cnf中f的[mysqld]一節中增加skip-name-resolve。選項就能禁用DNS解析,連接速度會快很多。不過,這樣的話就不能在MySQL的授權表中使用主機名了而只能用ip格式。

若使用–skip-grant-tables系統將對任何用戶的訪問不做任何訪問控制,但可以用 mysqladmin flush-privileges或mysqladmin reload來開啟訪問控制;默認情況是show databases語句對所有用戶開放,

如果mysql服務器沒有開遠程帳戶,就在my.cnf裡面加上skip-grant-tables。


在linux下配置文件是/etc/my.cnf,在windows下配置文件是mysql安裝目錄下的my.ini文件。注意該配置是加在 [mysqld]下面,在更改配置並保存後,然後重啟mysql並遠程連接測試,一切恢復如初。該參數的官方解釋信息如下:

mysql主機查詢DNS很慢或是有很多客戶端主機時會導致連接很慢,由於我們的開發機器是不能夠連接外網的,所以DNS解析是不可能完成的,從而也就明白了為什麼連接那麼慢了。同時,請注意在增加該配置參數後,mysql的授權表中的host字段就不能夠使用域名而只能夠使用 ip地址了,因為這是禁止了域名解析的結果

copyright © 萬盛學電腦網 all rights reserved