解決MYSQL"ACCESS DENIED FOR USER'ROOT'@'IP地址'"問題

用這個方法測試沒法讓全部機器均可以登陸mysql服務器,只能一次設置單個ip登陸,緣由暫時不知道;mysql

 
關於只能設置單個ip登陸:查看musql的user表發現緣由是‘%’用戶設置了密碼,在修改mysql數據庫的‘%’用戶的密碼爲‘’,即空的時候,就能夠實現全部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的機器上運行:
一、d:\mysql\bin\>mysql -h localhost -u root
//這樣應該能夠進入MySQL服務器
二、mysql>GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION
//賦予任何主機訪問數據的權限
三、mysql>FLUSH PRIVILEGES
//修改生效
四、mysql>EXIT
//退出MySQL服務器
這樣就能夠在其它任何的主機上以root身份登陸啦!
相關文章
相關標籤/搜索