mysql 遠程連接數據庫


 

一、連接數據庫:

1、連接遠程數據庫

登陸遠程數據庫需要指明遠程數據庫所在服務器的IP地址或者域名,以及端口號,

mysql -h mysql服務器的IP地址 -P 端口號(通常為3306) -u 用戶名 -p密碼       

-h: mysql服務器的IP地址
-P: 大寫的P選項表示端口號,端口號默認為3306,可省略
-u: 用戶名
-p: 小寫的p表示密碼,當-p后輸入密碼時,會直接登陸。當-p后不輸入密碼時,會要求輸入密碼,但密碼不顯示

 

如:MySQL 連接遠程數據庫(192.168.5.116),端口“3306”,用戶名為“root”,密碼“123456”

mysql -h 192.168.5.116 -P 3306 -u root -p123456   //顯示密碼登陸

 

mysql -h 192.168.5.116 -P 3306 -u root -p    //隱藏密碼登陸
Enter password:

 

2、連接本地數據庫

因為是本地連接,所以不需要指明服務器地址,當然,若是指明也可以登陸

  mysql  -u 用戶名 -p
  mysql -h localhost -u 用戶名 -p

  mysql -h 本地iP地址 -u 用戶名 -p

 

 

二、配置mysql允許遠程鏈接

    默認情況下,mysql帳號不允許從遠程登陸,只能在localhost登錄。本文提供了二種方法設置mysql可以通過遠程主機進行連接。

一、改表法

    在localhost登入mysql后,更改 "mysql" 數據庫里的 "user" 表里的 "host" 項,將"localhost"改稱"%"

例如:
  #mysql -u root -p
   Enter password:
    ……
   mysql>use mysql;
  mysql>update user set host = '%' where user = 'root';

  mysql>select host, user from user;

 

二、授權法

 1.允許某個用戶在任何主機可以訪問mysql服務器

GRANT ALL PRIVILEGES ON *.* TO '用戶名'@'%'IDENTIFIED BY '密碼' WITH GRANT OPTION;
FLUSH PRIVILEGES;

%表示任何主機
 
        

例如: 你想myuser使用mypassword(密碼)從任何主機連接到mysql服務器的話。

mysql>GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'%'IDENTIFIED BY 'mypassword' WITH GRANT OPTION;
mysql>FLUSH PRIVILEGES;

 1.允許某個用戶在在指定的主機可以訪問mysql服務器,在指定主機以外的主機則無法訪問數據庫

GRANT ALL PRIVILEGES ON *.* TO '用戶名'@'指定主機的IP地址'IDENTIFIED BY '密碼' WITH GRANT OPTION;

 

  如果你想允許用戶myuser從ip為192.168.1.6的主機連接到mysql服務器,並使用mypassword作為密碼

mysql>GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'192.168.1.3'IDENTIFIED BY 'mypassword' WITH GRANT OPTION;
mysql>FLUSH PRIVILEGES;

 

常見問題: 

1、在采用法二授權法之后,無法在本地使用本地IP地址登錄mysql(如:
#mysql -u root -p -h 192.168.5.116
Enter password: 
ERROR 1045 (28000): Access denied for user 'root'@'loadb116' (using password: YES)

上例中loadb116是主機名.

解決方法: 
1、這時可以使用: mysql  -u root -p 登錄,進入到mysql后。
mysql> grant all privileges on *.* to 'root'@'loadb116' identified by '123456' with grant option; 
Query OK, 0 rows affected (0.00 sec)
mysql> flush privileges; 
Query OK, 0 rows affected (0.00 sec)

 


2、執行完上面的命令后,即可在本地使用本地的ip地址登錄
# mysql -u root -p -h 192.168.5.116 
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or /g.
Your MySQL connection id is 60
Server version: 5.1.45 MySQL Community Server (GPL)

Type 'help;' or '/h' for help. Type '/c' to clear the buffer.

 


免責聲明!

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



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