windows下用navicat遠程鏈接虛擬機Linux下MySQL數據庫(轉)


原文地址:https://www.cnblogs.com/blogforly/p/5997553.html

       今天想用navicat遠程連接虛擬機中的MySQL數據庫,一直連不上,在網上搜索了一下,發現原因是MySQL對遠程用戶登陸的授權問題。這里說一下我的解決方法。(本人小白)

  首先,我用navicat去遠程鏈接我虛擬機中的MySQL,鏈接測試失敗。

  然后在虛擬機中查看網絡端口信息:

  #netstat -ntpl

 

       之后查看了防火牆的狀態,發現3306端口的數據包都是丟棄狀態

  #iptables -vnL

       這里要清除防火牆中鏈中的規則

  #iptables -F

  在這之后,我又遠程鏈接了一下MySQL,出現了以下錯誤,查了一下,是因為MySQL沒有允許遠程登陸,所以要授權MySQL遠程登陸。

這里先說一下MySQL登陸:

  格式: mysql -h主機地址 -u用戶名-p用戶密碼


    1、例1:連接到本機上的MYSQL
    找到mysql的安裝目錄,一般可以直接鍵入命令mysql -uroot -p,回車后提示你輸密碼,輸入密碼,直接回車即可進入到MYSQL中了,MYSQL的提示符是:mysql>

    2、連接到遠程主機上的MySQL
    假設遠程主機的IP為:10.0.0.1,用戶名為root,密碼為123。則鍵入以下命令:
    mysql -h10.0.0.1 -uroot -p123
   (注:p與123(密碼)之間最好不加空格,其它也一樣)

    3、退出MySQL命令
   exit (回車)

最后授權MySQL,允許遠程用戶登錄訪問MySQL

  手動增加可以遠程訪問數據庫的用戶。

  方法一、本地登入mysql,更改 "mysql" 數據庫里的 "user" 表里的 "host" 項,將"localhost"改為"%"

  #mysql -u root -proot
  mysql>use mysql;
  mysql>update user set host = '%' where user = 'root';
  mysql>select host, user from user;


  方法二、直接授權(推薦)

  從任何主機上使用root用戶,密碼:youpassword(你的root密碼)連接到mysql服務器:
  # mysql -u root -proot 
  mysql>GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'youpassword' WITH GRANT OPTION;

  操作完后切記執行以下命令刷新權限 
    FLUSH PRIVILEGES

   這時再通過navicat遠程鏈接MySQL,鏈接測試,成功。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM