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

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


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

相关推荐
Evan芙4 小时前
RDBMS的库、表、视图、索引、设计范式总结
数据库
一叶飘零_sweeeet4 小时前
从单机到集群:Redis部署全攻略
数据库·redis·缓存
soft20015255 小时前
MySQL Buffer Pool深度解析:LRU算法的完美与缺陷
数据库·mysql·算法
C++业余爱好者5 小时前
SQL Server 中数据库管理系统、数据库实例与数据库的关系与区别
数据库·oracle
保护我方头发丶5 小时前
ESP-wifi-蓝牙
前端·javascript·数据库
tgethe5 小时前
mysql-视图详解
数据库·mysql
Ged.phoenix7 小时前
Mysql架构
mysql·架构
漂亮的小碎步丶7 小时前
【6】数据库事务与锁机制详解(附并发结算案例)
数据库·事务·锁机制
北极糊的狐7 小时前
MySQL报错Communications link failure(通信链路失败)
数据库·mysql