mysql连接1130 - host_用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的时候要在语句完成后加上" ; "下面是图示说明

b7bb0e68f0b234664c93eb75aa6224e2.png

遇到这个问题首先到mysql所在的服务器上用连接进行处理

连接服务器: mysql -u root -p

2e079c06ff92779dac6636dde285c38e.png

查看当前所有数据库:show databases;

1aa8724f9ef6cab218e15dc1801f0c67.png

进入mysql数据库:use mysql;

fe581fd090d99b4e9e4be6134c80e78a.png

查看mysql数据库中所有的表:show tables;

657e561561b96dd4c8638532b9c32e21.png

查看user表中的数据:select Host, User,Password from user;

bce6696c83208651a285a2ee7de442d7.png

修改user表中的Host:update user set Host='%' where User='root';

4a4b652d7c20810bd398ed06e1e444d1.png

最后刷新一下:flush privileges;

8a663aab1e608f527416b38170127bb0.png

重新在Navicate中测试一下:

9e45454d2aa52b877bef3b4c7f21a99e.png

第一种问题的解决办法是:

在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

第三种不解释了.

(还有一种方法说是关闭服务器防火墙:# service iptables stop  不建议使用这种方法,会引发未知的安全问题)

很明显最后还是没有解决,在网上的资料很多都是重复的,最后实在没办法,找了师兄帮忙才发现是阿里云控制台这边的问题,说明自己思考的方向还是不对.具体的解决方法是:

打开云服务器ECS

打开左边菜单的实例

打开实例最右边的管理

打开左边菜单的本实例安全组

打开右边的配置规则

右上角添加安全组规则

协议类型默认自定义,端口范围:3306/3306,授权对象:0.0.0.0/0,其他默认就行

确定后重启服务器

连接OK!

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值