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

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


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

相关推荐
qianshang23315 分钟前
SQL注入学习总结
网络·数据库·渗透
what丶k41 分钟前
深入解析Redis数据持久化:RBD机制原理、实操与生产最佳实践
数据库·redis·缓存
瀚高PG实验室1 小时前
通过数据库日志获取数据库中的慢SQL
数据库·sql·瀚高数据库
Hgfdsaqwr2 小时前
Python在2024年的主要趋势与发展方向
jvm·数据库·python
invicinble2 小时前
对于Mysql深入理解
数据库·mysql
阳光九叶草LXGZXJ2 小时前
达梦数据库-学习-47-DmDrs控制台命令(LSN、启停、装载)
linux·运维·数据库·sql·学习
Hgfdsaqwr2 小时前
掌握Python魔法方法(Magic Methods)
jvm·数据库·python
s1hiyu3 小时前
使用Scrapy框架构建分布式爬虫
jvm·数据库·python
2301_763472463 小时前
使用Seaborn绘制统计图形:更美更简单
jvm·数据库·python
熊文豪3 小时前
金仓数据库如何以“多模融合“重塑文档数据库新范式
数据库·金仓数据库·电科金仓·mongodb迁移