解決mysql"Access denied for user'root'@'IP地址'"問題
在MYSQL 中,用遠程軟件登陸服務器,有時出現:Access denied for user 'root'@'localhost' www.2cto.com
出現這種問題,主要的原因就是權限配置的時候 沒有配置正確。
解決方法如下:
當用Linux/unix的tty 登陸進MYSQL 時, mysql -u root -p 會提示你輸入密碼,輸入正確的密碼後正常登陸。
然後在提示符下,打命令:show grants; 會出現root如下的權限表示:GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' IDENTIFIED BY PASSWORD '565491d704013245' WITH GRANT OPTION
此時,注意看那個“@”後面的,是localhost 意思是本機登陸,,此時,如果你用遠程登陸軟件來登陸的話,會出現錯誤提示:Access denied for user 'root'@'IP地址'。。IP地址那塊是你遠程機器的IP地址。也就是服務器在告訴你,當你用“IP地址”登陸時,是拒絕的,因為,MYSQL權限設置裡並沒有給你對應你IP地址登陸的權限。因為剛才的SHOW GRANTS;命令結果已經告訴你了,僅限本機登陸。
那解決方法如下:此時,你可以嘗試用空密碼連接,是可以連接進入的。或者你在服務器的tty 或者pts操作台中進入服務器後執行如下的命令:
grant all privileges on *.* to 'root'@'%' with grant option;
意思是讓root在所有機器都可以登陸到MYSQL服務器(擁有所有權限)。當執行完這條命令後,用客戶端登陸,此時,是需要輸入口令了。
GRANT ALL PRIVILEGES
1。 改表法。可能是你的帳號不允許從遠程登陸,只能在localhost。這個時候只要在localhost的那台電腦,登入mysql後,更改 "mysql" 數據庫裡的 "user" 表裡的 "host" 項,從"localhost"改稱"%"
Sql代碼
1. mysql -u root -pvmwaremysql>use mysql;
2. mysql>update user set host = '%' where user = 'root';
3. mysql>select host, user from user;
2. 授權法。例如,你想myuser使用mypassword從任何主機連接到mysql服務器的話。
Sql代碼
1. GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'%' IDENTIFIED BY 'mypassword' WITH
GRANT OPTION;
2.FLUSH PRIVILEGES;
如果你想允許用戶myuser從ip為192.168.1.6的主機連接到mysql服務器,並使用mypassword作為密碼
Sql代碼
1. GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'192.168.1.3' IDENTIFIED BY
2. 'mypassword' WITH GRANT OPTION;
3. FLUSH PRIVILEGES;
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作為密碼
Sql代碼
1. GRANT ALL PRIVILEGES ON dk.* TO 'myuser'@'192.168.1.3' IDENTIFIED BY
2. 'mypassword' WITH GRANT OPTION;
3. FLUSH PRIVILEGES;
GRANT ALL PRIVILEGES ON dk.* TO 'myuser'@'192.168.1.3' IDENTIFIED BY
'mypassword' WITH GRANT OPTION;
FLUSH PRIVILEGES;
注意授權後必須FLUSH PRIVILEGES;否則無法立即生效。
另外一種方法.
在安裝mysql的機器上運行:
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身份登錄啦!