第一种方式

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设置共享内存多少合适 docker容器间共享内存_运维


基础镜像

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: 指定容器是否为特权容器,用操作系统具备一定的权力