MySQL 进行 Docker 容器化之体验

原则

Docker 的使用原则是全部容器化的应用程序都应该是无状态的,即容器内部只跑业务逻辑,容器应用的全部配置文件、日志文件和持久化数据都应该挂载到宿主机文件系统,不该该存储在容器内部,以避免容器被误删或自身出现问题致使数据丢失。mysql

MySQL 容器化方式

MySQL 属于有状态应用,若将其容器化需将其状态抽离到宿主机,其配置文件、日志文件和持久化数据都应该挂载到宿主机。sql

容器内各路径

经过 docker pull 命令拉取下来的官方 MySQL 镜像内,有几个重要路径:docker

  • 配置文件
    镜像内 MySQL 的配置文件路径为 /etc/mysql,路径下包含 my.cnf 配置和一个 conf.d 文件夹,my.cnf 文件内是一些 base setting,咱们自定义的配置应该写在 conf.d 文件夹下的配置文件里,从而覆盖 base settingconf.d 文件夹下默认有两个配置文件:docker.cnfmysql.cnf,在后文所讲的挂载配置路径到宿主机以后,应将这两个用户自定义配置文件拷贝到宿主机配置路径下。
  • 持久化数据
    镜像内 MySQL 的持久化数据均存储在 /var/lib/mysql 下。

命令

$ docker run \
    --name db \
    -e MYSQL_ROOT_PASSWORD=secret \
    -v /path/to/confdir:/etc/mysql/conf.d \
    -v /path/to/datadir:/var/lib/mysql \
    -d
    mysql:tag

可根据须要加入 --restart 参数来指定容器自动重启策略,详见:
https://docs.docker.com/engin...rest

参数解释

  • --name 容器名称
  • -e 为新容器设置环境变量,容器内 MySQL 会以此初始化 root 用户密码
  • -v 两个 -v 参数分别将容器内 MySQL 的自定义配置文件目录和持久化数据目录挂载到宿主机,冒号前为宿主机目录,后为容器内目录
  • -d 后台启动容器

小技巧

咱们能够在宿主机专门创建一个目录用来存放容器状态数据,层级结构为:日志

docker-container-data
    |
     - container1
    |   |
    |    - conf
    |   |
    |    - logs (其下又能够细分路径)
    |   |
    |    - data
    |
     - container2
    |
     - container3
    |
     ...

灾难措施

将状态数据挂载宿主机的好处就是若是容器发生问题,能够启动一个新容器并将容器状态路径挂载到宿主机上的原状态路径,从而恢复生产。
能够直接将新启动的 MySQL 容器的配置和持久化数据挂载到以前容器的宿主路径,新容器即可以无缝恢复数据(配置、用户、库、表、记录均恢复)。code

注意事项

  • 不能够将两个均在运行的容器的状态路径挂载到同一个宿主路径,两个容器同时在一个宿主路径下写状态,容器应用读取状态时会没法识别,致使崩溃。
  • 若新启动的容器要挂载以前容器的宿主数据路径,则会忽略 -e MYSQL_ROOT_PASSWORD=foo 命令参数所设定的 root 用户密码环境变量,由于挂载的数据路径下已经包含了 MySQL 用户信息表,而 root 用户的密码以前已经被设定过了。
相关文章
相关标签/搜索