報錯:1130-host ... is not allowed to connect to this MySql server 開放mysql遠程鏈接 不使用localhost

執行以下命令報錯html

mysql -uroot -h${hostIp} -p
Enter password:*********
ERROR 1130 (HY000): Host '$hostIp' is not allowed to connect to this MySQL server

解決方法:
1。 改表法。
多是你的賬號不容許從遠程登錄,只能在localhost。這個時候只要在localhost的那臺電腦,登入mysql後,更改 "mysql" 數據庫裏的 "user" 表裏的 "host" 項,從"localhost"改稱"%"mysql

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

2. 受權法。
例如,你想myuser使用mypassword從任何主機鏈接到mysql服務器的話。sql

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

若是你想容許用戶myuser從ip爲192.168.1.6的主機鏈接到mysql服務器,並使用mypassword做爲密碼數據庫

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

若是你想容許用戶myuser從ip爲192.168.1.6的主機鏈接到mysql服務器的dk數據庫,並使用mypassword做爲密碼服務器

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

我用的第一個方法,剛開始發現不行,在網上查了一下,少執行一個語句 mysql>FLUSH RIVILEGES 使修改生效.就能夠了
另一種方法,不過我沒有親自試過的,在csdn.net上找的,能夠看一下.
在安裝mysql的機器上運行:
this

1、d:\mysql\bin\>mysql   -h   localhost   -u   root //這樣應該能夠進入MySQL服務器
2、mysql>GRANT   ALL   PRIVILEGES   ON   *.*   TO   'root'@'%'   WITH   GRANT   OPTION //賦予任何主機訪問數據的權限
3、mysql>FLUSH   PRIVILEGES //修改生效
4、mysql>EXIT //退出MySQL服務器

這樣就能夠在其它任何的主機上以root身份登陸啦!spa

 

參考地址:http://www.cnblogs.com/xyzdw/archive/2011/08/11/2135227.html.net

相關文章
相關標籤/搜索