数据卷容器
如果用户需要在多个容器之间共享一些持续更新的数据,最简单的方式是使用数据卷容器。数据卷容器也是一个容器,但是它的目的是专门用来提供数据卷供其他容器挂载。
基础镜像
docker pull centos:7.8.2003
docker pull nginx:1.19.3-alpine
docker pull mysql:5.7.31
数据卷容器
docker run -d --name data-volume -v /data/nginx:/usr/share/nginx/html -v
/data/mysql:/var/lib/mysql centos:7.8.2003
发现创建好的数据卷容器是处于停止运行的状态,因为使用 —volumes-from 参数所挂载数据卷的容器自己并不需要保持在运行状态。
docker run -itd --name nginx01 -p 80:80 --volumes-from data-volume nginx:1.19.3-alpine
echo "lagouedu nginx" > /data/nginx/index.html
http://192.168.198.100
docker run -itd --name nginx02 -p 81:80 --volumes-from data-volume nginx:1.19.3-alpine
http://192.168.198.100:81
docker run -itd --name mysql01 --restart always --privileged=true -p 3306:3306 -e MYSQL_ROOT_PASSWORD=admin --volumes-from data-volume mysql:5.7.31 --character-set-server=utf8 --collation-server=utf8_general_ci
docker run -itd --name mysql02 --restart always --privileged=true -p 3307:3306-e MYSQL_ROOT_PASSWORD=admin --volumes-from data-volume mysql:5.7.31 --character-set-server=utf8 --collation-server=utf8_general_ci
说明
- –volumes-from, 挂载到数据卷容器 数据卷容器名称
- -e , --env=[]: 设置环境变量,容器中可以使用该环境变量;docker官网查询进行设置环境变量
- -i, --interactive=false: 以交互模式运行容器,通常与 -t 同时使用
- -t, --tty=false: 为容器重新分配一个伪输入终端,通常与 -i 同时使用
- -p, --publish=[]: 指定端口映射,格式为:主机(宿主)端口:容器端口
- -d, --detach=false: 后台运行容器,并返回容器ID
- –character-set-server=utf8 --collationserver=utf8_general_ci 向my.cnf文件中追加相关配置项
- –restart=no:指定容器停止后的重启策略 no:容器退出时不重启 on-failure:容器故障退出(返回值非零)时重启 always:容器退出时总是重启,推荐使用
- –privileged=false: 指定容器是否为特权容器,用操作系统具备一定的权力