当前位置: 首页 > news >正文

解决 MySQL 数据库无法远程连接的问题

在使用 MySQL 数据库时,遇到这样的问题:

本地可以连接 MySQL,但远程机器连接时,总是报错 Host ... is not allowed to connect to this MySQL server

这通常是因为 MySQL 的用户权限或配置限制了远程访问。

1. 登录 MySQL 数据库

首先,使用本地命令行登录 MySQL:

mysql -u root -p

输入 root 用户的密码进入数据库。


2. 切换到 mysql 系统库

MySQL 的用户权限存放在 mysql 数据库中,我们需要切换到它:

USE mysql;

3. 查看当前用户和主机权限

执行以下命令查看当前 MySQL 用户的 host 设置:

SELECT User, Host FROM mysql.user;

你会看到一张表,例如:

+------------------+-----------+
| User             | Host      |
+------------------+-----------+
| root             | localhost |
| mysql.session    | localhost |
| mysql.sys        | localhost |
+------------------+-----------+

注意到 root 用户的 Hostlocalhost,这表示它 只能从本机连接,无法被远程机器连接。

4. 修改 root 用户的 Host 为 %

要允许 root 用户从任意主机连接,需要把它的 Host 改成 %(表示任意主机):

UPDATE mysql.user SET host='%' WHERE user='root' AND host='localhost';

5. 刷新权限生效

修改完权限后,需要刷新权限表才能生效:

FLUSH PRIVILEGES;

执行以下命令查看当前 MySQL 用户的 host 设置:

SELECT User, Host FROM mysql.user;

你会看到一张表,root的host被设置为了%,表示可以接受远程连接

+------------------+-----------+
| User             | Host      |
+------------------+-----------+
| root             | %         |
| mysql.session    | localhost |
| mysql.sys        | localhost |
+------------------+-----------+

不出意外的话,现在你已经可以进行远程连接了,如果还有问题可以进行6-7的排查

6. 检查 MySQL 配置文件

有时候,MySQL 的配置文件 my.cnf(或 my.ini)会限制绑定的地址,默认只监听 127.0.0.1

  • 打开配置文件:

    vim /etc/my.cnf
    
  • 找到 [mysqld] 部分,修改:

    bind-address = 0.0.0.0
    

    这表示监听所有 IP,而不仅是本机。

  • 保存后,重启 MySQL:

    systemctl restart mysqld
    

7. 确认防火墙是否开放 3306 端口

MySQL 默认端口是 3306,linux为例确保服务器防火墙允许远程访问:

# 查看防火墙状态
firewall-cmd --list-all# 开放 3306 端口(仅 firewalld 示例)
firewall-cmd --add-port=3306/tcp --permanent
firewall-cmd --reload

8. 总结

要解决 MySQL 无法远程连接的问题,可以按照下面的步骤排查:

  1. 修改 mysql.user 表,把 root 的 Host 改为 %
  2. 刷新权限
  3. 检查是否可以链接,不可以的话需要检查配置和端口防火墙
  4. 检查 my.cnf 配置,确保 bind-address0.0.0.0
  5. 检查防火墙是否开放 3306 端口
http://www.xdnf.cn/news/357319.html

相关文章:

  • 一场陟遐自迩的 SwiftUI + CoreData 性能优化之旅(下)
  • 介质访问控制(MAC)
  • sqli-labs靶场18-22关(http头)
  • 数据分析与逻辑思维:六步解决业务难题;参考书籍《数据分析原理:6步解决业务分析难题 (周文全, 黄怡媛, 马炯雄)》
  • C# WinForm 如何高效地将大量数据从 CSV 文件导入 DataGridView
  • JavaScript 基础
  • 成龙电影中的三菱汽车
  • 退货处理费归零:亚马逊卖家年度成本节省路径解析
  • 硅基计划 学习总结 拾贰
  • WebSocket与Socket.IO实现简易客服聊天系统全解析
  • Spring Web MVC快速入门
  • [css]纯css绘制三角形
  • MindSpore框架学习项目-ResNet药物分类-数据增强
  • HTML应用指南:利用POST请求获取全国德邦快递服务网点位置信息
  • C++中extern关键字详解:不同情况下的使用方式
  • Text Based Person Search 研究进展汇报:主要问题、数据集、未来方向
  • ATH12K驱动框架架构图
  • vue3 全局注册自定义指令,input聚焦失焦展示对应值
  • Java LocalDateTime类详解:高效处理日期时间
  • 面试题:Java集合框架高频面试题总结
  • 何时需要import css文件?怎么知道需要导入哪些css文件?为什么webpack不提示CSS导入?(导入css导入规则、css导入规范)
  • Nginx修改日志时间格式
  • WHAT - 用户访问产品个性化延迟问题和技术手段
  • 从投入产出、效率、上手难易度等角度综合对比 pytest 和 unittest 框架
  • 第三节:条件语句与循环:控制程序流程
  • 特殊配合力(SCA)作为全基因组关联分析(GWAS)的表型,其生物学意义和应用价值
  • MQTT:轻量级物联网通信协议详解
  • Vulnhub Lazysysadmin靶机攻击实战(一)
  • logback日志输出到项目运行目录
  • Git_idea界面进行分支合并到主分支详细操作