執行以下命令報錯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