MySQL 8 开启远程登录

前言

在日常开发和运维工作中,我们经常需要从远程客户端连接MySQL数据库。MySQL 8默认出于安全考虑,只允许本地连接。本文将详细介绍如何安全地开启MySQL 8的远程访问功能。

环境信息

  • MySQL版本:8.0.44-0ubuntu0.24.04.1
  • 系统:Ubuntu 24.04

完整步骤

1. 登录MySQL服务器

bash 复制代码
mysql -u root -p

2. 处理密码策略问题(如遇报错)

在创建远程用户时,可能会遇到密码策略限制:

sql 复制代码
-- 查看当前密码策略
SHOW VARIABLES LIKE 'validate_password%';

-- 如果密码过于简单,可临时降低策略等级
SET GLOBAL validate_password.policy = LOW;

注意:生产环境建议保持强密码策略,使用复杂密码。

3. 创建远程访问用户

sql 复制代码
-- 创建允许任意主机连接的root用户(生产环境不推荐)
CREATE USER 'root'@'%' IDENTIFIED BY '你的安全密码';

-- 更安全的做法:创建专用远程用户
CREATE USER 'remote_user'@'%' IDENTIFIED BY '强密码';

4. 授予权限

sql 复制代码
-- 授予所有权限(根据实际需要调整)
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%';

-- 或者授予特定权限(推荐)
GRANT SELECT, INSERT, UPDATE, DELETE ON 数据库名.* TO 'remote_user'@'%';

5. 刷新权限

sql 复制代码
FLUSH PRIVILEGES;

6. 退出MySQL

sql 复制代码
EXIT;

配置MySQL允许远程连接

修改MySQL配置文件

bash 复制代码
# 编辑MySQL配置文件
sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf

找到bind-address配置项并修改:

ini 复制代码
# 将127.0.0.1改为0.0.0.0或注释掉
bind-address = 0.0.0.0
# 或直接注释
# bind-address = 127.0.0.1

重启MySQL服务

bash 复制代码
sudo systemctl restart mysql
# 或
sudo service mysql restart

防火墙配置

如果系统启用了防火墙,需要开放3306端口:

bash 复制代码
# UFW防火墙(Ubuntu)
sudo ufw allow 3306

# firewalld(CentOS/RHEL)
sudo firewall-cmd --permanent --add-port=3306/tcp
sudo firewall-cmd --reload

安全建议

1. 使用专用用户而非root

sql 复制代码
-- 创建专用远程用户
CREATE USER 'db_remote'@'%' IDENTIFIED BY '复杂密码123!@#';

-- 按需授权
GRANT SELECT, INSERT, UPDATE ON 特定数据库.* TO 'db_remote'@'%';

2. 限制访问IP

sql 复制代码
-- 只允许特定IP段访问
CREATE USER 'secure_user'@'192.168.1.%' IDENTIFIED BY '密码';

3. 恢复密码策略

sql 复制代码
-- 操作完成后恢复密码策略
SET GLOBAL validate_password.policy = MEDIUM;

4. 定期检查用户权限

sql 复制代码
-- 查看用户权限
SELECT user, host FROM mysql.user;
SHOW GRANTS FOR '用户名'@'%';

测试远程连接

从远程客户端测试连接:

bash 复制代码
mysql -h 服务器IP -u 用户名 -p

故障排除

常见问题及解决方案

  1. 连接被拒绝

    • 检查防火墙设置
    • 确认MySQL绑定地址配置
    • 验证用户主机权限
  2. 权限错误

    • 确认用户有远程访问权限
    • 检查GRANT语句是否正确执行
  3. 密码策略问题

    • 使用更复杂的密码
    • 适当调整密码策略等级

总结

开启MySQL远程访问需要综合考虑安全性和便利性。建议遵循最小权限原则,为不同的使用场景创建专用用户,并定期审计权限设置。

记得在生产环境中操作前进行充分测试,并做好相应的安全防护措施。


温馨提示:本文中的操作示例仅供参考,请根据实际环境调整配置。重要的生产环境操作前请务必备份数据。

相关推荐
睡不醒男孩0308234 小时前
第二篇:深入探索开源数据库高可用:构建基于CLup的PostgreSQL生产级高可用与读写分离架构
数据库·postgresql·开源·clup
Micro麦可乐6 小时前
Spring Boot 实战:从零设计一个短链系统(含完整代码与数据库设计)
数据库·spring boot·后端·哈希算法·雪花算法·短链系统
码农阿豪6 小时前
从零到一:Spring Boot快速接入金仓数据库实战
数据库·spring boot·后端
鼎讯信通6 小时前
风电光缆运维提质增效:G-4000A 光缆故障追踪仪破解风场巡检难题
运维·网络·数据库
三十..7 小时前
MySQL 从入门到高可用架构实战精要
运维·数据库·mysql
cfm_29147 小时前
Redis五大基本数据结构底层了解
数据结构·数据库·redis
真实的菜8 小时前
Redis 从入门到精通(十二):典型业务场景实战 —— 排行榜、限流器、秒杀系统、Session 共享
数据库·redis·python
你想考研啊8 小时前
mysql数据库导出导入
数据库·mysql·oracle
会Tk矩阵群控的小木8 小时前
安卓群控系统对于游戏工作室实战教程
android·运维·游戏·adb·开源软件·个人开发
十年编程老舅9 小时前
Linux DRM:底层逻辑与实践架构
数据库·mysql