Host is not allowed to connect to this MySQL server解决方法

在阿里云服务器上安装了Mysql数据库,在阿里云上使用一切正常。我用navicat 去连接服务器时显示Host is not allowed to connect to this MySQL server。

​ 看见这个错误,第一反应是是不是阿里云服务器防火墙没有配置mysq的出入站规则。去阿里云检查了一下发现并不是这个原因。然后就去网上找资料。

​ 这个错误,其实就是我们的MySQL不允许远程登录,所以远程登录失败了,解决方法如下:

  • 在装有MySQL的机器上登录
sql 复制代码
MySQL mysql -u root -p密码
  • 执行
sql 复制代码
use mysql;
  • 执行
sql 复制代码
update user set host = '%' where user = 'root';
  • 执行
sql 复制代码
FLUSH PRIVILEGES;
  • 经过上面4步,就可以解决这个问题了。

最后:

​ 在数据库中查询:select user,host from user ;

修改以后的root 账号的host 是% ,而其他的账号则为localhost 。我们可以看出host的作用是限制ip地址登录。localhost 是仅为本地登录。%为通配符,可以使任意ip地址进行登录访问。

在找资料的时候看见的,觉得以后可能会看,就先放在这里了。

相关推荐
sthnyph2 小时前
初识MySQL · 库的操作
数据库·mysql
原来是猿2 小时前
MySQL【视图】
数据库·mysql
2401_873587822 小时前
MySQL——事务管理
数据库·mysql
0xDevNull3 小时前
MySQL 三大日志系统深度解析:Binlog、Redo Log、Undo Log
数据库·mysql
Java面试题总结3 小时前
htop安装不了怎么解决
mysql
钰衡大师3 小时前
MySQL 数据库备份方案
数据库·mysql
原来是猿5 小时前
MySQL【事务下】
数据库·mysql·oracle
奕成则成5 小时前
面试被问:MySQL 与 Doris/SelectDB 的架构区别。 大数据为什么禁止select *。
mysql·面试·架构
gjc5925 小时前
踩坑实录:MySQL服务器CPU爆高,元凶竟是SELinux的setroubleshootd?
运维·服务器·数据库·mysql·adb
Bat U6 小时前
MySQL数据库|建库&建表&数据类型
数据库·mysql