MySQL遠端訪問時非常慢的解決

2021-08-30 01:32:55 字數 1564 閱讀 3053

伺服器放在區域網內進行測試時,資料庫的訪問速度還是很快。但當伺服器放到外網後,資料庫的訪問速度就變得非常慢。

後來在網上發現解決方法,my.cnf裡面新增

[mysqld]

skip-name-resolve

這樣速度就快了!

skip-name-resolve

選項就能禁用dns解析,連線速度會快很多。不過,這樣的話就不能在mysql的授權表中使用主機名了而只能用ip格式。

還有許可權的問題,當使用者設定限制只能訪問某個資料庫,如果這個資料庫被刪了,再重建這個指定資料庫,限制使用者還是不能訪問這個資料,大概是刪除資料庫的時間,把該使用者的訪問許可權也級聯刪除了,詳細可以檢視mysql.db的記錄

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

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

排除網路問題。

就mysql本身而言,問題出在在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

發現有非常多的 unauthenticated user 嘗試做登入使用 mysql 的情況 ,當這種情況無限制發生時就會造成系統十分緩慢。

查閱mysql官方**得知,這屬於官方乙個系統上的特殊設定,就把他當成mysql的乙個bug算了,不管鏈結的的方式是經過 hosts 或是 ip 的模式,他都會對 dns 做反查。mysqld 會嘗試去反查 ip -> dns ,由於反查解析過慢,就會無法應付過量的查詢。

解決辦法:

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

加 --skip-name-resolve 這麼乙個引數就可以,關閉mysql的dns反查功能。

或者修改mysql配置檔案。

在[mysqld]段中加入

skip-name-resolve

重啟mysql

在/etc/my.cnf 的配置檔案中加入如下一句,禁用dns反響解析,就能大大加快mysql連線的速度。

[mysqld]

下面加上這句

skip-name-resolve

#注意有些文章中寫道加入–skip-name-resolve,經驗證,在centos5下加入–skip-name-resolve會導致mysql守護程序無法啟動。估計在其他linux系統下是一樣的,windows下沒有測試,skip-name-resolve應該就可以。

文章出處:

MySQL遠端訪問時非常慢的解決方法

伺服器放在區域網內進行測試時,資料庫的訪問速度還是很快。但當伺服器放到外網後,資料庫的訪問速度就變得非常慢。後來在網上發現解決方法,my.ini裡面新增 mysqld skip name resolve 這樣速度就快了 skip name resolve 選項就能禁用dns解析,連線速度會快很多。不...

stackoverflow 訪問非常慢的解決辦法

stackoverflow是開發常用的提問和解決 問題 但自己訪問總是非常的慢,幾十秒甚至幾分鐘 我們可以對 stackoverflow只是訪問速度很慢,但終歸可以開啟,如果被牆不可能最後開啟的,所以排除。資源 jquery.min.js 這個資源請求一直處於阻塞狀態,發現其實是請求谷歌的jquer...

PHP遠端連線MYSQL資料庫非常慢的解決方法

不知道如何解決,所以把他空間所在的伺服器上也裝了個mysql,才解決問題,今天又有個這個問題,不能也在這伺服器上裝乙個mysql吧,search php遠端連線mysql速度慢,有時遠端連線到mysql用時4 20秒不等,本地連線mysql正常,出現這種問題的主要原因是,預設安裝的mysql開啟了d...