MySQL 官方 Docker 镜像的使用

本贴最后更新于 2764 天前,其中的信息可能已经时移世改

Docker 镜像是创建容器的基础,我们可以基于官方提供镜像或自已构建的镜像来创建容器,而自己构建的镜像往往又基于基于官方基础镜像构建。mysql 是 Docker 及 MySQL 提供、维护的一个官方镜像,我们可以基于该镜像构建自己的 MySQL 数据库镜像,也可以直接使用这个镜像创建 MySQL 数据库容器。在笔者所参与的项目中,MySQL 数据库使用频率较高,因此对该镜像的使用做简单的整理、介绍。

1. 启动一个 mysql 服务器实例

使用 mysql 镜像创建或启动 MySQL 容器时,可以先将镜像下载到本地:

$ docker pull mysql

也可以直接使用以下命令来启动 MySQL 实例:

$ docker run --name itbilu-mysql -e MYSQL_ROOT_PASSWORD=my-pass -d mysql:5.7

这样,我们就创建了一个名为 itbilu-mysql 的 MySQL 数据库服务器容器实例。在创建数据库时,通过环境变量 MYSQL_ROOT_PASSWORD 设置数据库的 root 密码,还通过 5.7 标签指定了所使用的镜像版本。

容器创建完成后,可以通过 docker ps 命令看到所创建的 MySQL 容器实例:

$ docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS               NAMES
872e8133e7ac        mysql:5.7           "docker-entrypoint..."   15 seconds ago      Up 14 seconds       3306/tcp            itbilu-mysql

2. 在其它 Docker 容器中应用中连接 MySQL

在这个镜像中,导出的是 MySQL 的标准端口 3306。这样我们就可以在需要访问 MySQL 服务器的容器中,使用 --link 参数通过容器链接的方式,将 MySQL 服务器容器实例连接到包含了需要使用 MySQL 的应用容器中。

使用容器连接的示例如下:

$ docker run --name some-app --link itbilu-mysql:mysql -d application-that-uses-mysql

注意:以上示例中的 application-that-uses- 镜像并不存在,仅为操作演示,下同。

除了进行容器连接的方式在其它容器中访问 MySQL 服务器容器外,还可以通过以下两种方式访问 MySQL 数据库服务器容器:

在创建 MySQL 服务器容器实例时通过 -p-P 参数将数据库服务器端口映射到宿主机,再直接通过宿主机进行访问。这种方式较为简单,但需要向外暴露数据库端口。
能过 Docker 网络(Networking)进行连接。这种方式操作较为复杂,但更为灵活,可以适用于更加复杂的网络环境。
详细参考如下:

3. MySQL 命令行客户端连接 MySQL

在前面创建的 MySQL 服务器容器中,我们并没有向外暴露访问端口,我们可以通过以下方式启动命令行客户端,并基于命令行客户端对数据库服务器进行管理。

运行另一个 MySQL 交互式容器,该容器会在运行后启动 mysql 命令行客户端:

$ docker run -it --link itbilu-mysql:mysql --rm mysql sh -c 'exec mysql -h"$MYSQL_PORT_3306_TCP_ADDR" -P"$MYSQL_PORT_3306_TCP_PORT" -uroot -p"$MYSQL_ENV_MYSQL_ROOT_PASSWORD"'

如果需要通过非 Docker 的方式,或远程访问 MySQL 服务器容器,就可以在创建容器时通过-p 或-P 与宿主机进行端口绑定,之后就可以像普通 MySQL 服务器那样进行访问或操作。

4. 在 Shell 中访问容器及日志查看

docker exec 命令使我们可以在 Docker 容器内部执行命令,我们可以通过以下方式与 mysql 容器建立一个 shell 连接:

$ docker exec -it itbilu-mysql bash
root@cc9417196c73:/# 

而 MySQL 服务器日志,可以直接通过 Docker 容器日志访问(实时日志查看可以添加-f 参数):

$ docker logs itbilu-mysql

5. 使用自定义 MySQL 配置文件

默认情况下,MySQL 的启动配置文件是 /etc/mysql/my.cnf,而 /etc/mysql/conf.d 目录下的存在任何 .cnf 格式的文件时,都会使用该文件中配置项替换默认配置。

因此,如果要使用自定义配置,可以在宿主机创建一个配置文件,然后在创建容器时通过-v 参数,以数据卷的方式将自定义配置挂载到 mysql 容器的 /etc/mysql/conf.d 目录下。

如,在宿主机中存在 /my/custom/config-file.cnf 配置文件,这时就可以通过以下方式启动 MySQL 容器:

$ docker run --name itbilu-mysql -v /my/custom:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=my-pass -d mysql:5.7

以上示例会启动一个名为 itbilu-mysql 的 MySQL 服务器容器,该文件启动时会同时使用 /etc/mysql/my.cnf/etc/mysql/conf.d/config-file.cnf 中的配置。

不使用 cnf 文件的配置方式

除使用.cnf 文件进行配置外,还可以在启动容器通过参数的形式将配置传递给 mysqld。

如,启动一个 MySQL 服务器容器,并使用 UTF-8(utf8mb4)格式的表编码:

$ docker run --name itbilu-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci

详细配置参数可以通过以下命令查看:

$ docker run -it --rm mysql:tag --verbose --help

6. 环境变量

当启动 mysql 容器时,我们可以向 docker run 命令传入一或多个环境变量来调整 MySQL 实例的配置。可设置的环境变量有:

  • MYSQL_ROOT_PASSWORD:必须。用于设置 MySQLroot 用户的密码
  • MYSQL_DATABASE:可选。用于指定镜像启动容器时要创建的数据库。如果提供了用户/密码,则会将该用户做为此数据库的超级用户。
  • MYSQL_USER,MYSQL_PASSWORD:可选。用于创建一个新用户并设置密码。
  • MYSQL_ALLOW_EMPTY_PASSWORD:可选。设置为 yes 时,则可以使用空密码登录
  • MYSQL_RANDOM_ROOT_PASSWORD:可选。设置为 yes 时会为 root 用户设置一个随机密码(使用 pwgen),所生成的随机密码会被输出到 stdout
  • MYSQL_ONETIME_PASSWORD:可选。为 root 用户指定一个一次性密码,该密码会在用户首次登录时强制修改
  1. 关于数据存储
    在使用 mysql 镜像创建 MySQL 容器时,数据库数据存储可能会有以下两种方式:

数据卷容器:使用 Docker 默认的数据管理方式来管理数据库的数据存储,在这种方式下,数据库文件会被写入数据库的内部。这种方式对于用户非常简单,缺点是很在宿主机上找到所存储的数据。
外部数据卷:在宿主机创建一个数据目录,再将数据目录挂载到容器内部。这种方式可以很方便的在宿主机上找到并进行数据管理,但需要确保数据目录的存在。
当使用外部数据卷时,假在宿主机有/my/own/datadir 目录,我们可以像下面这样启动 mysql 容器,并将目录挂载到容器内:

$ docker run --name itbilu-mysql -v /my/own/datadir:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag

其中,-v /my/own/datadir:/var/lib/mysql 是数据卷的挂载,表示将宿主机的 /my/own/datadir 目录挂载到容器内的 /var/lib/mysql 目录。这个目录是 MySQL 的默认数据目录,当使用自定义配置时,应该也做相应的修改。

数据库备份

在非 Docker 环境下使用的 MySQL 备份工具,大多数在容器环境下仍然可用,只要其能访问 mysqld 服务器即可。

下面是一个通过 docker exec 来对 mysql 容器中的数据库执行备份的示例:

$ docker exec some-mysql sh -c 'exec mysqldump --all-databases -uroot -p"$MYSQL_ROOT_PASSWORD"' > /some/path/on/your/host/all-databases.sql
  • MySQL

    MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是最流行的关系型数据库管理系统之一。

    692 引用 • 535 回帖
  • 软件
    31 引用 • 31 回帖
  • Docker

    Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的操作系统上。容器完全使用沙箱机制,几乎没有性能开销,可以很容易地在机器和数据中心中运行。

    492 引用 • 926 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...