Docker 的使用原则是全部容器化的应用程序都应该是无状态的,即容器内部只跑业务逻辑,容器应用的全部配置文件、日志文件和持久化数据都应该挂载到宿主机文件系统,不该该存储在容器内部,以避免容器被误删或自身出现问题致使数据丢失。mysql
MySQL 属于有状态应用,若将其容器化需将其状态抽离到宿主机,其配置文件、日志文件和持久化数据都应该挂载到宿主机。sql
经过 docker pull
命令拉取下来的官方 MySQL 镜像内,有几个重要路径:docker
/etc/mysql
,路径下包含 my.cnf
配置和一个 conf.d
文件夹,my.cnf
文件内是一些 base setting
,咱们自定义的配置应该写在 conf.d
文件夹下的配置文件里,从而覆盖 base setting
。conf.d
文件夹下默认有两个配置文件:docker.cnf
和 mysql.cnf
,在后文所讲的挂载配置路径到宿主机以后,应将这两个用户自定义配置文件拷贝到宿主机配置路径下。/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 用户的密码以前已经被设定过了。