遠端連線mysql資料庫注意事項記錄(遠端連線慢skip-name-resolve)_Mysql

來源:互聯網
上載者:User

一、如何建立獨立帳號並設定許可權

  這裡我使用Navicat作為我的資料庫管理工具,開啟Navicat。

選擇“使用者”--“建立使用者”

輸入使用者名稱、主機、密碼,需要注意的是,主機那不是寫“localhost”,而是寫“%”

然後可以設定“伺服器許可權”

和指定資料庫的許可權,最後儲存退出即可

二、遠端連線慢

  慢是一個很大的問題,網上的辦法是在my.ini的“[mysqld]”下面加入一行“skip-name-resolve”,就像這樣:

  然後儲存並重啟mysql服務即可。

下面是其它網友的補充:

問題現象是這樣的:

我在一台機器上(61.183.23.23)啟動了一個mysql,然後開通一個帳號可以從127.0.0.1或者從61.183.23.23訪問。但是遇到一個問題就是使用下面兩個命令列訪問的時候,速度差別非常大:

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

然後我使用ping,判斷兩個IP的速度差不多。

使用127.0.0.1的IP速度比另一個快太多了。雖然說這裡的61.183.23.23需要去外網走一圈,但是速度差別怎麼會差這麼多。

解決辦法:

mysql使用skip-name-resolve禁止掉DNS的查詢。
mysql會在使用者登入過程中對用戶端IP進行DNS反查,不管你是使用IP登入還是網域名稱登入,這個反查的過程都是在的。所以如果你的mysql所在的伺服器的DNS有問題或者品質不好,那麼就有可能造成我遇到的這個問題,DNS解析出現問題。

修改mysql設定檔

[mysqld]
skip-name-resolve

補充:

做個提醒,增加skip-name-resolve有可能導致帳號失效,比如我原先的帳號是yejianfeng@localhost,然後其實我使用mysql -h127.0.0.1 -uyejianfeng 是可以登入的。但是一旦加上了skip-name-resolve,就不能登入的了。需要加上帳號yejianfeng@127.0.0.1

資料庫加這個參數速度會變快skip-name-resolve,但是也有注意點,mysql.user 表裡面的 host 不要用 localhost 之類的,要用127.0.0.1不然連自己都連不上資料庫,會報錯

我現在都是先不加skip-name-resolve,現在建立一個root使用者不過域是127.0.0.1,然後再把skip-name-resolve加上,就可以使用root登入了,建立使用者直接用127.0.0.1,這樣就OK了。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.