MySQL在遠端訪問時非常慢的解決方法
伺服器放在區域網內進行測試時,資料庫的訪問速度還是很快。但當伺服器放到外網後,資料庫的訪問速度就變得非常慢。
後來在網上發現解決方法,my.cnf裡面新增
[mysqld]
skip-name-resolve
這樣速度就快了!
skip-name-resolve
選項就能禁用DNS解析,連線速度會快很多。不過,這樣的話就不能在MySQL的授權表中使用主機名了而只能用ip格式。
還有許可權的問題,當使用者設定限制只能訪問某個資料庫,如果這個資料庫被刪了,再重建這個指定資料庫,限制使用者還是不能訪問這個資料,大概是刪除資料庫的時間,把該使用者的訪問許可權也級聯刪除了,詳細可以檢視mysql.db的記錄
若使用–skip-grant-tables系統將對任何使用者的訪問不做任何訪問控制,但可以用mysqladmin flush-privileges或mysqladminreload來開啟訪問控制;預設情況是showdatabases語句對所有使用者開放。
如果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配置檔案。
編輯/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應該就可以。
另外就是在資料庫的伺服器上,etc/hosts,加上類似如下
192.168.1.2 vmware-2
192.168.1.3 vmware-3
後來在網上發現解決方法,my.cnf裡面新增
[mysqld]
skip-name-resolve
這樣速度就快了!
skip-name-resolve
選項就能禁用DNS解析,連線速度會快很多。不過,這樣的話就不能在MySQL的授權表中使用主機名了而只能用ip格式。
還有許可權的問題,當使用者設定限制只能訪問某個資料庫,如果這個資料庫被刪了,再重建這個指定資料庫,限制使用者還是不能訪問這個資料,大概是刪除資料庫的時間,把該使用者的訪問許可權也級聯刪除了,詳細可以檢視mysql.db的記錄
若使用–skip-grant-tables系統將對任何使用者的訪問不做任何訪問控制,但可以用mysqladmin flush-privileges或mysqladminreload來開啟訪問控制;預設情況是showdatabases語句對所有使用者開放。
如果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配置檔案。
編輯/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應該就可以。
另外就是在資料庫的伺服器上,etc/hosts,加上類似如下
192.168.1.2 vmware-2
192.168.1.3 vmware-3
就很快了。
相關文章
- MySQL遠端訪問時,非常慢,甚至出現連不上的情況MySql
- GitHub訪問速度慢的解決方法Github
- 解決github訪問慢的問題Github
- 解決mysql無法遠端登入的方法MySql
- 遠端連線 Mysql 失敗的解決方法MySql
- 解決mysql不能遠端連線的問題MySql
- mysql如何允許遠端訪問MySql
- mysql賬戶新增遠端訪問MySql
- MySQL限制IP網段範圍從遠端訪問的方法MySql
- 比較好用的遠端軟體 及時解決遠端問題
- navicat無法遠端連線mysql的解決方法MySql
- 【轉】允許遠端使用者登入訪問mysql的方法MySql
- mysql實現遠端訪問,phpmyadmin實現遠端連線mysqlMySqlPHP
- Oracle如何診斷遠端訪問資料庫慢/超時等問題小結Oracle資料庫
- Github訪問速度慢的解決方案Github
- 在Terminal中通過代理訪問GitHub(解決訪問GitHub速度慢的問題)Github
- 解決windows docker lnmp訪問慢問題WindowsDockerLNMP
- 解決Ubuntu下MySQL遠端登入問題UbuntuMySql
- Mysql資料庫的遠端訪問設定MySql資料庫
- mysql5.7.22-log 修改遠端訪問MySql
- 開啟mysql遠端登入訪問功能MySql
- mysql8.0授權root遠端訪問MySql
- mysql8.x docker遠端訪問配置詳解硨磬MySqlDocker
- 遠端服務不能啟動問題的解決方法
- Redis遠端訪問Redis
- GitHub無法訪問或訪問緩慢解決辦法Github
- shutdown遠端關機win10系統拒絕訪問最佳解決方法Win10
- C#訪問遠端主機資源的方法C#
- mysql例項停止、啟動、配置遠端訪問MySql
- Linux中開啟MySQL遠端訪問功能LinuxMySql
- win10遠端桌面很慢怎麼解決_win10遠端桌面連線慢的解決步驟Win10
- win10 photoshop啟動非常慢怎麼解決_win10 photoshop啟動非常慢優化方法Win10優化
- TeamViewer遠端訪問View
- 鐵威馬NAS遠端訪問設定方法
- 如何解決 github 訪問慢的問題Github
- SSH遠端連結超時斷開的三種解決方法
- MySQL 開啟 3306 埠遠端訪問MySql
- ssh登入慢問題解決方法