溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

MySQL在遠(yuǎn)程訪(fǎng)問(wèn)時(shí)非常慢的解決skip-name-resolve

發(fā)布時(shí)間:2020-06-27 19:50:17 來(lái)源:網(wǎng)絡(luò) 閱讀:3306 作者:Mr_sheng 欄目:MySQL數(shù)據(jù)庫(kù)

服務(wù)器放在局域網(wǎng)內(nèi)進(jìn)行測(cè)試時(shí),數(shù)據(jù)庫(kù)的訪(fǎng)問(wèn)速度還是很快。但當(dāng)服務(wù)器放到外網(wǎng)后,數(shù)據(jù)庫(kù)的訪(fǎng)問(wèn)速度就變得非常慢。

后來(lái)在網(wǎng)上發(fā)現(xiàn)解決方法,my.cnf里面添加

[mysqld]
skip-name-resolve

這樣速度就快了!

skip-name-resolve

選項(xiàng)就能禁用DNS解析,連接速度會(huì)快很多。不過(guò),這樣的話(huà)就不能在MySQL的授權(quán)表中使用主機(jī)名了而只能用ip格式。

還有權(quán)限的問(wèn)題,當(dāng)用戶(hù)設(shè)置限制只能訪(fǎng)問(wèn)某個(gè)數(shù)據(jù)庫(kù),如果這個(gè)數(shù)據(jù)庫(kù)被刪了,再重建這個(gè)指定數(shù)據(jù)庫(kù),限制用戶(hù)還是不能訪(fǎng)問(wèn)這個(gè)數(shù)據(jù),大概是刪除數(shù)據(jù)庫(kù)的時(shí)間,把該用戶(hù)的訪(fǎng)問(wèn)權(quán)限也級(jí)聯(lián)刪除了,詳細(xì)可以查看mysql.db的記錄

若使用–skip-grant-tables系統(tǒng)將對(duì)任何用戶(hù)的訪(fǎng)問(wèn)不做任何訪(fǎng)問(wèn)控制,但可以用 mysqladmin flush-privileges或mysqladmin reload來(lái)開(kāi)啟訪(fǎng)問(wèn)控制;默認(rèn)情況是show databases語(yǔ)句對(duì)所有用戶(hù)開(kāi)放。

如果mysql服務(wù)器沒(méi)有開(kāi)遠(yuǎn)程帳戶(hù),就在my.cnf里面加上skip-grant-tables

排除網(wǎng)絡(luò)問(wèn)題。

就MySQL本身而言,問(wèn)題出在在mysql dns反解析

mysql>show processlist;

| 20681949 | unauthenticated user | 10.10.4.193:52497 | NULL | Connect | | Reading from net | NULL | 
| 20681948 | unauthenticated user | 10.10.4.193:52495 | NULL | Connect | | Reading from net | NULL

發(fā)現(xiàn)有非常多的 unauthenticated user 嘗試做登入使用 mysql 的情況 ,當(dāng)這種情況無(wú)限制發(fā)生時(shí)就會(huì)造成系統(tǒng)十分緩慢。

查閱mysql官方網(wǎng)站得知,這屬于官方一個(gè)系統(tǒng)上的特殊設(shè)定,就把他當(dāng)成mysql的一個(gè)bug算了,不管鏈接的的方式是經(jīng)過(guò) hosts 或是 IP 的模式,他都會(huì)對(duì) DNS 做反查。mysqld 會(huì)嘗試去反查 IP -> dns ,由于反查解析過(guò)慢,就會(huì)無(wú)法應(yīng)付過(guò)量的查詢(xún)。

解決辦法:

/usr/local/mysql/bin/mysqld_safe --skip-name-resolve --user=mysql&

加 --skip-name-resolve 這么一個(gè)參數(shù)就可以,關(guān)閉mysql的dns反查功能。

或者修改mysql配置文件。

編輯/etc/my.cnf

在[mysqld]段中加入

skip-name-resolve

重啟mysql

在/etc/my.cnf 的配置文件中加入如下一句,禁用DNS反響解析,就能大大加快MySQL連接的速度。
[mysqld]

下面加上這句
skip-name-resolve

#注意有些文章中寫(xiě)道加入–skip-name-resolve,經(jīng)驗(yàn)證,在CentOS5下加入–skip-name-resolve會(huì)導(dǎo)致mysql守護(hù)進(jìn)程無(wú)法啟動(dòng)。估計(jì)在其他linux系統(tǒng)下是一樣的,windows下沒(méi)有測(cè)試,skip-name-resolve應(yīng)該就可以。

**************************************


下面是其它網(wǎng)友的補(bǔ)充:

問(wèn)題現(xiàn)象是這樣的:

我在一臺(tái)機(jī)器上(61.183.23.23)啟動(dòng)了一個(gè)mysql,然后開(kāi)通一個(gè)賬號(hào)可以從127.0.0.1或者從61.183.23.23訪(fǎng)問(wèn)。但是遇到一個(gè)問(wèn)題就是使用下面兩個(gè)命令行訪(fǎng)問(wèn)的時(shí)候,速度差別非常大:

mysql –h 127.0.0.1 –u user
mysql –h 61.183.23.23 –u user

然后我使用ping,判斷兩個(gè)IP的速度差不多。

使用127.0.0.1的IP速度比另一個(gè)快太多了。雖然說(shuō)這里的61.183.23.23需要去外網(wǎng)走一圈,但是速度差別怎么會(huì)差這么多。

解決辦法:

mysql使用skip-name-resolve禁止掉DNS的查詢(xún)。
mysql會(huì)在用戶(hù)登錄過(guò)程中對(duì)客戶(hù)端IP進(jìn)行DNS反查,不管你是使用IP登錄還是域名登錄,這個(gè)反查的過(guò)程都是在的。所以如果你的mysql所在的服務(wù)器的DNS有問(wèn)題或者質(zhì)量不好,那么就有可能造成我遇到的這個(gè)問(wèn)題,DNS解析出現(xiàn)問(wèn)題。

修改mysql配置文件

[mysqld]
skip-name-resolve

補(bǔ)充:

做個(gè)提醒,增加skip-name-resolve有可能導(dǎo)致賬號(hào)失效,比如我原先的賬號(hào)是yejianfeng@localhost,然后其實(shí)我使用mysql -h227.0.0.1 -uyejianfeng 是可以登錄的。但是一旦加上了skip-name-resolve,就不能登錄的了。需要加上賬號(hào)yejianfeng@127.0.0.1


向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI