Docker部署远程MySQL从端口踩坑到权限全开完整步骤(附避坑指南)

 更新时间:2026年04月20日 09:15:04   作者:rrrjqy  
MySQL远程连接问题是软件开发与数据库运维过程中极为常见且令人困扰的技术难题,其背后涉及权限控制、网络通信、系统安全策略及容器化部署等多个层面的协同机制,这篇文章主要介绍了Docker部署远程MySQL从端口踩坑到权限全开的相关资料,需要的朋友可以参考下

一、部署环境与核心工具

  • 服务器:阿里云轻量应用服务器(Ubuntu/CentOS 均可)
  • 核心技术:Docker + Docker Compose
  • 数据库版本:MySQL 8.0
  • 本地连接工具:DataGrip

二、基础部署流程:三步走方案

1. 目录隔离与 Docker Compose 配置

version: '3.8'
services:
  new-db:
    image: mysql:8.0
    container_name: xxx-db  # 容器名称
    restart: always
    environment:
      MYSQL_ROOT_PASSWORD: xxx  # root用户密码
      MYSQL_DATABASE:xxx_db  # 自动创建的数据库名
    ports:
      - "3307:3306"  # 关键!宿主机端口:容器端口
    volumes:
      - ./mysql_data:/var/lib/mysql  # 数据持久化挂载

核心配置解析:

端口映射 3307:3306:外部连接必须使用宿主机端口(本处如果是3307记得改因为3306就是 MySQL 数据库的“官方出厂默认端口”如果改了宿主机端口记得改)

持久化挂载:避免容器删除后数据丢失

2. 一键启动服务

docker compose up -d

三、血泪避坑指南:解决“连不上”的三个死理

坑位 1:Connection timed out

症状

DataGrip 提示 [28000][1045] Connection timed out: connect

原因

云服务器安全组默认拦截非标准端口(如 3307)

解决方案

登录云服务器控制台
在安全组中添加入方向规则:
协议:TCP
端口范围:3307
授权对象:0.0.0.0/0(生产环境建议限制 IP)

坑位 2:误把容器名当用户名

症状

Access denied for user ‘resumer-db’@‘xxx’

原因

混淆了容器名(xxx-db)与数据库用户名(root)

解决方案

在连接工具中填写:

User: root
Password: xxx(即 MYSQL_ROOT_PASSWORD 的值)

坑位 3:MySQL 8.0 的权限与加密限制

症状

Access denied for user ‘root’@‘你的IP’ (using password: YES)

原因

权限限制:root 默认仅允许 localhost 访问

加密冲突:MySQL 8.0 默认使用 caching_sha2_password,旧客户端不支持

解决方案:

docker exec -it resumer-db mysql -uroot -proot -e \
"ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'root'; \
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION; \
FLUSH PRIVILEGES;"

命令解析

修改 root 用户加密方式为 mysql_native_password

授权所有 IP(%)访问

立即刷新权限

连不上 → 查云服务器安全组
账号错误 → 确认使用 root 而非容器名
密码错误 → 解决 MySQL 8.0 权限与加密问题
理清这三点,从此告别数据库连接报错!

​总结

到此这篇关于Docker部署远程MySQL从端口踩坑到权限全开的文章就介绍到这了,更多相关Docker部署远程MySQL内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL 索引从入门到精通示例详解(核心概念、类型与实战优化)

    MySQL 索引从入门到精通示例详解(核心概念、类型与实战优化)

    本文详细介绍了MySQL索引的概念、类型及其在实际应用中的优化策略,索引可以显著提升查询效率,但过多的索引会增加写操作的开销,文章涵盖了索引的创建、维护和使用技巧,帮助读者更好地理解和应用索引,以优化数据库性能,感兴趣的朋友跟随小编一起看看吧
    2026-01-01
  • MySQL触发器实现两表数据同步的代码详解

    MySQL触发器实现两表数据同步的代码详解

    在数据库应用中,我们经常需要对数据进行某些操作,并在操作完成后进行相应的处理,这时候,可以使用触发器来实现这些功能,MySQL提供了强大的触发器功能,本文将给大家详细介绍MySQL触发器实现两表数据同步,需要的朋友可以参考下
    2023-12-12
  • 如何用mysqldump进行全量和时间点备份

    如何用mysqldump进行全量和时间点备份

    这篇文章主要介绍了如何用mysqldump进行全量和时间点备份,帮助大家更好的管理MySQL数据库,感兴趣的朋友可以了解下
    2020-08-08
  • MySQL8.0.27安装过程中卡在Initializing Database中并报错的解决

    MySQL8.0.27安装过程中卡在Initializing Database中并报错的解决

    本文主要介绍了MySQL8.0.27安装过程中卡在Initializing Database中并报错的解决,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-05-05
  • Ubuntu 20.04 安装和配置MySql5.7的详细教程

    Ubuntu 20.04 安装和配置MySql5.7的详细教程

    这篇文章主要介绍了Ubuntu 20.04 安装和配置MySql5.7的相关资料,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12
  • MySQL与PHP的基础与应用专题之数据查询语句

    MySQL与PHP的基础与应用专题之数据查询语句

    MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,本系列将带你掌握php与mysql的基础应用,本篇从数据查询语句开始
    2022-02-02
  • Mysql如何按照范围区间创建分区表

    Mysql如何按照范围区间创建分区表

    在Mysql的范围分区表定义中,分区范围需要连续并且不会有覆盖,定义范围分区表时,使用VALUES LESS THAN操作符,这篇文章主要介绍了Mysql如何按照范围区间创建分区表,需要的朋友可以参考下
    2024-08-08
  • MySQL中pt-table-checksum实现主从一致性校验的终极方案

    MySQL中pt-table-checksum实现主从一致性校验的终极方案

    pt-table-checksum 凭借低侵入性、高准确性和良好的兼容性,成为 MySQL 主从一致性校验的首选工具,下面就来详细的介绍一下MySQL中pt-table-checksum实现主从一致性校验,感兴趣的可以了解一下
    2026-04-04
  • mysql 控制台程序的提示符 prompt 字符串设置

    mysql 控制台程序的提示符 prompt 字符串设置

    mysql 控制台程序的提示符 prompt 字符串设置,学习mysql的朋友可以参考下。
    2011-08-08
  • mysql数据库密码忘记解决方法

    mysql数据库密码忘记解决方法

    大家好,本篇文章主要讲的是mysql数据库密码忘记解决方法,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览
    2021-12-12

最新评论