第一种方式
cp命令
当然还有最原始的copy方式,这个也是管理数据的方式,但是基本不会用到。
docker cp :用于容器与主机之间的数据拷贝。
语法
宿主机文件复制到容器内
docker cp [OPTIONS] SRC_PATH CONTAINER:DEST_PATH
容器内文件复制到宿主机
docker cp [OPTIONS] CONTAINER:SRC_PATH DEST_PATH
基础镜像
docker pull nginx:1.19.3-alpine
容器内文件 copy to 宿主机内
宿主机的index.html页面覆盖容器内的index.html页面
docker run -itd --name nginx -p 80:80 nginx:1.19.3-alpine
cd /data
docker cp nginx:/usr/share/nginx/html/index.html /data/index.html
cat /data/index.html
宿主机文件 copy to 容器内
宿主机的index.html页面覆盖容器内的index.html页面
docker run -itd --name nginx -p 80:80 nginx:1.19.3-alpine
cd /data
echo "laosiji" > /data/index.html
docker cp /data/index.html nginx:/usr/share/nginx/html/index.html
浏览器测试
http://192.168.198.100
常用参数
-L :保持源目标中的链接
第二种方式
宿主机数据卷使用
语法
docker run -v /宿主机绝对路径目录:/容器内目录 镜像名
基础镜像
docker pull mysql:5.7.31
运行镜像
推荐还是先创建好目录后再进行数据挂载
docker run -itd --name mysql --restart always --privileged=true -p 3306:3306 -e MYSQL_ROOT_PASSWORD=admin -v /data/mysql:/var/lib/mysql mysql:5.7.31 --
character-set-server=utf8 --collation-server=utf8_general_ci
说明
- -v, 数据卷 /宿主机绝对路径目录:/容器内目录
- -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: 指定容器是否为特权容器,用操作系统具备一定的权力
第三种方式
数据卷容器
如果用户需要在多个容器之间共享一些持续更新的数据,最简单的方式是使用数据卷容器。数据卷容器也是一个容器,但是它的目的是专门用来提供数据卷供其他容器挂载。
基础镜像
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: 指定容器是否为特权容器,用操作系统具备一定的权力