MySQL远程连接拒绝访问?一招修改root权限解决(适用MySQL 8)
一、问题描述
使用 IntelliJ IDEA 或其他客户端连接 openEuler MySQL 服务器时报错:
ERROR 1410 (42000): You are not allowed to create a user with GRANT
或者:Access denied for user 'root'@'%'
文章目录
作者简介
猫头虎是谁?
大家好,我是 猫头虎,猫头虎技术团队创始人,也被大家称为猫哥。我目前是COC北京城市开发者社区主理人、COC西安城市开发者社区主理人,以及云原生开发者社区主理人,在多个技术领域如云原生、前端、后端、运维和AI都具备丰富经验。
我的博客内容涵盖广泛,主要分享技术教程、Bug解决方案、开发工具使用方法、前沿科技资讯、产品评测、产品使用体验,以及产品优缺点分析、横向对比、技术沙龙参会体验等。我的分享聚焦于云服务产品评测、AI产品对比、开发板性能测试和技术报告。
目前,我活跃在CSDN、51CTO、腾讯云、阿里云开发者社区、知乎、微信公众号、视频号、抖音、B站、小红书等平台,全网粉丝已超过30万。我所有平台的IP名称统一为猫头虎或猫头虎技术团队。
我希望通过我的分享,帮助大家更好地掌握和使用各种技术产品,提升开发效率与体验。
作者名片 ✍️
- 博主:猫头虎
- 全网搜索关键词:猫头虎
- 作者微信号:Libin9iOak
- 作者公众号:猫头虎技术团队
- 更新日期:2025年06月12日
- 🌟 欢迎来到猫头虎的博客 — 探索技术的无限可能!
加入我们AI共创团队 🌐
- 猫头虎AI共创社群矩阵列表:
加入猫头虎的共创圈,一起探索编程世界的无限可能! 🚀
部分专栏链接
:
🔗 精选专栏:
- 《面试题大全》 — 面试准备的宝典!
- 《IDEA开发秘籍》 — 提升你的IDEA技能!
- 《100天精通鸿蒙》 — 从Web/安卓到鸿蒙大师!
- 《100天精通Golang(基础入门篇)》 — 踏入Go语言世界的第一步!
正文
二、原因分析
MySQL 8.0 对权限控制更严格,root@localhost
默认不能创建或授权给其他来源地址的 root 用户。
所以直接执行:
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION;
会报错。
三、正确做法:修改 root 用户的 host
✅ 步骤1:登录数据库
mysql -u root -p
✅ 步骤2:切换到 mysql 权限库
USE mysql;
✅ 步骤3:修改 root 的 host 为通配符
UPDATE user SET Host='%' WHERE User='root' AND Host='localhost';
FLUSH PRIVILEGES;
✅ 步骤4:授权远程权限
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION;
FLUSH PRIVILEGES;
✅ 验证:
SELECT Host, User FROM user WHERE User='root';
四、安全建议
不推荐在生产环境中让 root
用户支持远程连接,推荐做法是:
CREATE USER 'devuser'@'192.168.10.%' IDENTIFIED BY 'Dev@2025';
GRANT ALL PRIVILEGES ON mydb.* TO 'devuser'@'192.168.10.%';
五、总结
通过修改 user
表中的 Host
字段并正确授权,可以安全开启 root 远程连接,适用于 MySQL 8 在 openEuler 等系统上的部署场景。
作者✍️ 猫头虎微信号:Libin9iOak
公众号:猫头虎技术团队
万粉变现经纪人:CSDNWF
粉丝福利
👉 更多信息:有任何疑问或者需要进一步探讨的内容,欢迎点击文末名片获取更多信息。我是猫头虎博主,期待与您的交流! 🦉💬
联系我与版权声明 📩
- 联系方式:
- 微信: Libin9iOak
- 公众号: 猫头虎技术团队
- 版权声明:
本文为原创文章,版权归作者所有。未经许可,禁止转载。更多内容请访问猫头虎的博客首页。
点击✨⬇️下方名片
⬇️✨,加入猫头虎AI共创社群矩阵。一起探索科技的未来,共同成长。🚀