服務器放在局域網內進行測試時,數據庫的訪問速度仍是很快。但當服務器放到外網後,數據庫的訪問速度就變得很是慢。mysql
後來在網上發現解決方法,my.cnf裏面添加linux
[mysqld]
skip-name-resolvesql
這樣速度就快了!數據庫
skip-name-resolvewindows
選項就能禁用DNS解析,鏈接速度會快不少。不過,這樣的話就不能在MySQL的受權表中使用主機名了而只能用ip格式。服務器
還有權限的問題,當用戶設置限制只能訪問某個數據庫,若是這個數據庫被刪了,再重建這個指定數據庫,限制用戶仍是不能訪問這個數據,大概是刪除數據庫的時間,把該用戶的訪問權限也級聯刪除了,詳細能夠查看mysql.db的記錄網絡
若使用–skip-grant-tables系統將對任何用戶的訪問不作任何訪問控制,但能夠用 mysqladmin flush-privileges或mysqladmin reload來開啓訪問控制;默認狀況是show databases語句對全部用戶開放。測試
若是mysql服務器沒有開遠程賬戶,就在my.cnf裏面加上skip-grant-tables網站
排除網絡問題。spa
就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配置文件。
編輯/etc/my.cnf
在[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應該就能夠。