本站支持搜索的镜像仓库:Docker Hub、gcr.io、ghcr.io、quay.io、k8s.gcr.io、registry.gcr.io、elastic.co、mcr.microsoft.com
** 注意 **:这是mysql官方镜像的amd64架构构建的“每个架构”仓库——更多信息,请参见官方镜像文档中的“除amd64之外的架构?”和官方镜像FAQ中的“镜像的源代码在Git中已更改,现在该怎么办?”。
-** 维护者 **:
Docker社区和MySQL团队
-** 获取帮助的地方 **:
Docker社区Slack、Server Fault、Unix & Linux或Stack Overflow
9.4.0, 9.4, 9, innovation, latest, 9.4.0-oraclelinux9, 9.4-oraclelinux9, 9-oraclelinux9, innovation-oraclelinux9, oraclelinux9, 9.4.0-oracle, 9.4-oracle, 9-oracle, innovation-oracle, oracle
8.4.6, 8.4, 8, lts, 8.4.6-oraclelinux9, 8.4-oraclelinux9, 8-oraclelinux9, lts-oraclelinux9, 8.4.6-oracle, 8.4-oracle, 8-oracle, lts-oracle
8.0.43, 8.0, 8.0.43-oraclelinux9, 8.0-oraclelinux9, 8.0.43-oracle, 8.0-oracle
8.0.43-bookworm, 8.0-bookworm, 8.0.43-debian, 8.0-debian
-** 问题反馈地址 :
[*]
-** 支持的架构 **:(更多信息)
amd64、arm64v8
-** 镜像 artifact 详情 **:
repo-info仓库的repos/mysql/目录(历史记录)
(镜像元数据、传输大小等)
-** 镜像更新 **:
official-images仓库的library/mysql标签
official-images仓库的library/mysql文件(历史记录)
-** 本描述的来源 **:
docs仓库的mysql/目录(历史记录)
MySQL是世界上最流行的开源数据库。凭借其经过验证的性能、可靠性和易用性,MySQL已成为基于Web的应用程序的首选数据库,涵盖从个人项目和网站,到电子商务和信息服务,再到包括***、、、***!等在内的高知名度网络属性。
有关MySQL Server和其他MySQL产品的更多信息及相关下载,请访问[***]
!logo
amd64/mysql服务器实例启动MySQL实例非常简单:
$ docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d amd64/mysql:tag
其中some-mysql是你要分配给容器的名称,my-secret-pw是要为MySQL root用户设置的密码,tag是指定你想要的MySQL版本的标签。请参见上面的列表获取相关标签。
以下命令启动另一个amd64/mysql容器实例,并针对原始amd64/mysql容器运行mysql命令行客户端,允许你对数据库实例执行SQL语句:
$ docker run -it --network some-network --rm amd64/mysql mysql -hsome-mysql -uexample-user -p
其中some-mysql是原始amd64/mysql容器的名称(连接到some-networkDocker网络)。
此镜像也可用作非Docker或远程实例的客户端:
$ docker run -it --rm amd64/mysql mysql -hsome.mysql.host -usome-mysql-user -p
有关MySQL命令行客户端的更多信息,请参见MySQL文档。
docker composemysql的compose.yaml示例:
# 使用root/example作为用户/密码凭据 services: db: image: mysql restart: always environment: MYSQL_ROOT_PASSWORD: example # (这只是示例,不旨在作为生产配置)
运行docker compose up,等待其完全初始化,然后访问http://localhost:8080或[***](视情况而定)。
docker exec命令允许你在Docker容器内运行命令。以下命令将为你提供amd64/mysql容器内的bash shell:
$ docker exec -it some-mysql bash
日志可通过Docker的容器日志查看:
$ docker logs some-mysql
MySQL的默认配置因基础镜像而异:
基于Oracle的镜像(默认):默认配置位于/etc/my.cnf,可能通过!includedir包含其他目录,如/etc/mysql/conf.d。
基于Debian的MySQL 8镜像:默认配置位于/etc/mysql/my.cnf,可能通过!includedir包含其他目录,如/etc/mysql/conf.d。
请在amd64/mysql镜像内检查相关文件和目录以获取更多详细信息。
如果/my/custom/config-file.cnf是你的自定义配置文件的路径和名称,你可以这样启动amd64/mysql容器(注意此命令中仅使用自定义配置文件的目录路径):
$ docker run --name some-mysql -v /my/custom:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=my-secret-pw -d amd64/mysql:tag
这将启动一个新容器some-mysql,其中MySQL实例使用默认配置文件和/etc/mysql/conf.d/config-file.cnf的组合启动设置,后者的设置优先。
许多配置选项可以作为mysqld的标志传递。这使你能够自定义容器而无需cnf文件。例如,如果你想将所有表的默认编码和排序规则更改为使用UTF-8(utf8mb4),只需运行以下命令:
$ docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d amd64/mysql:tag --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
如果你想查看所有可用选项的完整列表,只需运行:
$ docker run -it --rm amd64/mysql:tag --verbose --help
启动amd64/mysql镜像时,你可以通过在docker run命令行上传递一个或多个环境变量来调整MySQL实例的配置。请注意,如果启动容器时数据目录已包含数据库,则以下变量均不会生效:任何预先存在的数据库在容器启动时都将保持不变。
另请参见[***]MYSQL_HOST等变量,已知在与此镜像一起使用时会导致问题)。
MYSQL_ROOT_PASSWORD此变量是必需的,指定将为MySQLroot超级用户账户设置的密码。在上面的示例中,它被设置为my-secret-pw。
MYSQL_DATABASE此变量是可选的,允许你指定在镜像启动时要创建的数据库名称。如果提供了用户/密码(见下文),则该用户将被授予对该数据库的超级用户访问权限(对应于GRANT ALL)。
MYSQL_USER、MYSQL_PASSWORD这些变量是可选的,结合使用以创建新用户并设置该用户的密码。此用户将被授予对MYSQL_DATABASE变量指定的数据库的超级用户权限(见上文)。创建用户需要这两个变量。
请注意,无需使用此机制创建root超级用户,该用户默认使用MYSQL_ROOT_PASSWORD变量指定的密码创建。
MYSQL_ALLOW_EMPTY_PASSWORD这是一个可选变量。设置为非空值(如yes),允许容器以root用户空密码启动。** 注意 **:除非你确实知道自己在做什么,否则不建议将此变量设置为yes,因为这会使你的MySQL实例完全不受保护,允许任何人获得完全的超级用户访问权限。
MYSQL_RANDOM_ROOT_PASSWORD这是一个可选变量。设置为非空值(如yes),为root用户生成随机初始密码(使用openssl)。生成的root密码将打印到标准输出(GENERATED ROOT PASSWORD: .....)。
MYSQL_ONETIME_PASSWORD初始化完成后将root用户(不是MYSQL_USER指定的用户!)设置为过期状态,强制首次登录时更改密码。任何非空值都将激活此设置。** 注意 **:此功能仅在MySQL 5.6+上受支持。在MySQL 5.5上使用此选项将在初始化期间抛出相应错误。
MYSQL_INITDB_SKIP_TZINFO默认情况下,入口点脚本会自动加载CONVERT_TZ()函数所需的时区数据。如果不需要,任何非空值都会禁用时区加载。
作为通过环境变量传递敏感信息的替代方法,可以将_FILE附加到前面列出的环境变量,使初始化脚本从容器中存在的文件加载这些变量的值。特别是,这可用于从存储在/run/secrets/<secret_name>文件中的Docker Secrets加载密码。例如:
$ docker run --name some-mysql -e MYSQL_ROOT_PASSWORD_FILE=/run/secrets/mysql-root -d amd64/mysql:tag
目前,仅MYSQL_ROOT_PASSWORD、MYSQL_ROOT_HOST、MYSQL_DATABASE、MYSQL_USER和MYSQL_PASSWORD支持此功能。
当容器首次启动时,将创建具有指定名称的新数据库,并使用提供的配置变量进行初始化。此外,它将执行/docker-entrypoint-initdb.d中找到的扩展名为.sh、.sql、.sql.gz、.sql.bz2、.sql.xz和.sql.zst的文件。文件将按字母顺序执行。当解析没有执行位的.sh文件时,它们会被source而不是执行。
你可以通过将SQL转储挂载到该目录并提供自定义镜像来轻松填充amd64/mysql服务。SQL文件默认将导入到MYSQL_DATABASE变量指定的数据库中。
重要提示:有多种方式存储Docker容器中运行的应用程序所使用的数据。我们鼓励amd64/mysql镜像的用户熟悉可用的选项,包括:
Docker文档是了解不同存储选项和变体的良好起点,有许多博客和论坛帖子讨论并提供了这方面的建议。我们在这里仅展示上述后一种选项的基本过程:
在主机系统的合适卷上创建数据目录,例如/my/own/datadir。
像这样启动amd64/mysql容器:
$ docker run --name some-mysql -v /my/own/datadir:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d amd64/mysql:tag
命令中的-v /my/own/datadir:/var/lib/mysql部分将底层主机系统的/my/own/datadir目录挂载为容器内的/var/lib/mysql,MySQL默认会在此处写入其数据文件。
如果容器启动时没有初始化数据库,则会创建默认数据库。虽然这是预期行为,但这意味着在初始化完成之前,它不会接受传入连接。当使用自动化工具(如Docker Compose)同时启动多个容器时,这可能会导致问题。
如果你尝试连接到MySQL的应用程序不能优雅地处理MySQL停机或等待MySQL启动,那么在服务启动前放置一个连接重试循环可能是必要的。有关官方镜像中此类实现的示例,请参见WordPress或Bonita。
如果你启动amd64/mysql容器实例时,数据目录已包含数据库(特别是mysql子目录),则$MYSQL_ROOT_PASSWORD变量应从运行命令行中省略;无论如何它都会被忽略,并且预先存在的数据库不会以任何方式更改。
如果你知道目录的权限已适当设置(例如针对现有数据库运行,如上所述),或者你需要以特定UID/GID运行mysqld,则可以使用--user将此镜像调用为任何值(root/0除外)以实现所需的访问/配置:
$ mkdir data $ ls -lnd data drwxr-xr-x 2 1000 1000 4096 Aug 27 15:54 data $ docker run -v "$PWD/data":/var/lib/mysql --user 1000:1000 --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d amd64/mysql:tag
大多数常规工具都可以使用,尽管在某些

免费版仅支持 Docker Hub 加速,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。
免费版仅支持 docker.io;专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等。
当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。
通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。
先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。
使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录方式配置轩辕镜像加速服务,包含7个详细步骤
在 Linux 系统上配置轩辕镜像源,支持主流发行版
在 Docker Desktop 中配置轩辕镜像加速,适用于桌面系统
在 Docker Compose 中使用轩辕镜像加速,支持容器编排
在 k8s 中配置 containerd 使用轩辕镜像加速
在宝塔面板中配置轩辕镜像加速,提升服务器管理效率
在 Synology 群晖NAS系统中配置轩辕镜像加速
在飞牛fnOS系统中配置轩辕镜像加速
在极空间NAS中配置轩辕镜像加速
在爱快ikuai系统中配置轩辕镜像加速
在绿联NAS系统中配置轩辕镜像加速
在威联通NAS系统中配置轩辕镜像加速
在 Podman 中配置轩辕镜像加速,支持多系统
配置轩辕镜像加速9大主流镜像仓库,包含详细配置步骤
无需登录即可使用轩辕镜像加速服务,更加便捷高效
需要其他帮助?请查看我们的 常见问题 或 官方QQ群: 13763429