用navicat連線資料庫報錯:1130-host ... is not allowed to connect to this MySql server如何處理
這個問題是因為在資料庫伺服器中的mysql資料庫中的user的表中沒有許可權(也可以說沒有使用者),下面將記錄我遇到問題的過程及解決的方法。
在搭建完LNMP環境後用Navicate連接出錯
遇到這個問題首先到mysql所在的伺服器上用連線進行處理
1、連線伺服器: mysql -u root -p
2、看當前所有資料庫:show databases;
3、進入mysql資料庫:use mysql;
4、檢視mysql資料庫中所有的表:show tables;
5、檢視user表中的資料:select Host, User,Password from user;
6、修改user表中的Host:update user set Host='%' where User='root';
7、最後重新整理一下:flush privileges;
#一定要記得在寫sql的時候要在語句完成後加上" ; "下面是圖示說明
遇到這個問題首先到mysql所在的伺服器上用連線進行處理
連線伺服器: mysql -u root -p
進入mysql資料庫:use mysql;
檢視mysql資料庫中所有的表:show tables;
檢視user表中的資料:select Host, User,Password from user;
修改user表中的Host:update user set Host='%' where User='root';
最後重新整理一下:flush privileges;
重新在Navicate中測試一下:
一種問題的解決辦法是:
在iptables中開放3306埠
#/sbin/iptables -I INPUT -p tcp --dport 3306 -j ACCEPT
#/etc/rc.d/init.d/iptables save 儲存:
# service iptables restart 重啟生效
############################################################################################
iptables -I INPUT -p TCP -s 0.0.0.0/0 --dport 3306 -j ACCEPT //我常用的在iptables中開放3306埠命令
第二種解決方法是:
設定遠端使用者訪問許可權:
// 任何遠端主機都可以訪問資料庫
mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%'WITH GRANT OPTION;
//需要輸入次命令使修改生效
mysql> FLUSH PRIVILEGES;
//退出
mysql> EXIT
原文連結:https://blog.csdn.net/dabao87/article/details/80571877