天天看點

mysql 遠端連接配接資料庫 - 豁然高

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.