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

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


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

相关推荐
百结2143 小时前
Mysql数据库操作
数据库·mysql·oracle
keep one's resolveY3 小时前
时区问题解决
数据库
Leinwin3 小时前
OpenClaw 多 Agent 协作框架的并发限制与企业化规避方案痛点直击
java·运维·数据库
qq_417695053 小时前
机器学习与人工智能
jvm·数据库·python
漫随流水3 小时前
旅游推荐系统(view.py)
前端·数据库·python·旅游
ego.iblacat3 小时前
MySQL 服务基础
数据库·mysql
Maverick065 小时前
Oracle Redo 日志操作手册
数据库·oracle
攒了一袋星辰5 小时前
高并发强一致性顺序号生成系统 -- SequenceGenerator
java·数据库·mysql
W.D.小糊涂6 小时前
gpu服务器安装windows+ubuntu24.04双系统
c语言·开发语言·数据库
云贝教育-郑老师6 小时前
【OceanBase 的多租户架构是怎样的?有什么优势?】
数据库·oceanbase