使用Dockerfile实现数据卷的挂载问题(推荐)
大家好,我们今天分享使用Dockerfile来实现数据卷的挂载
首先呢,要了解一下什么是Dockerfile
Dockerfile就是 一个可以用来构建镜像的文件,可以理解为一个脚本文件
可以通过这个脚本文件自定义生成一个我们想要的镜像,镜像都是一层一层的,里面的每一条命令就是一层
创建一个目录
root@localhost home]# mkdir docker-vl2
编辑这样这样的一个文件
root@localhost docker-vl2]# vim dockerfile01
FROM centos VOLUME ["volume01","volume02"] CMD echo "------end-----" CMD /bin/bash ~ ~ ~ ~
保存退出:
构建成新的镜像,注意看shuaige/centos:2.0有一个小点
[root@localhost docker-vl2]# docker build -f dockerfile01 -t shuaige/centos:2.0 . Sending build context to Docker daemon 2.048kB Step 1/4 : FROM centos ---> 5d0da3dc9764 Step 2/4 : VOLUME ["volume01","volume02"] ---> Running in 96445950bbef Removing intermediate container 96445950bbef ---> ffcf0eb8973b Step 3/4 : CMD echo "------end-----" ---> Running in a4fa6fce633b Removing intermediate container a4fa6fce633b ---> 5416582373e0 Step 4/4 : CMD /bin/bash ---> Running in 7d7df79e0b36 Removing intermediate container 7d7df79e0b36 ---> d8e0f44b8da3 Successfully built d8e0f44b8da3 Successfully tagged shuaige/centos:2.0
看这个过程,一共有4步,对应着我们刚刚写的dockerfile 文件
也是一层一层的

查看镜像:

这样,我们的这个dockerfile 文件就构建成功了
进入我们自己写的容器
[root@localhost docker-vl2]# docker run -it d8e0f44b8da3 /bin/bash [root@b36bc0c1e4a9 /]#
查看容器内部的文件结构:
[root@b36bc0c1e4a9 /]# ls -l total 0 lrwxrwxrwx. 1 root root 7 Nov 3 2020 bin -> usr/bin drwxr-xr-x. 5 root root 360 Mar 8 14:09 dev drwxr-xr-x. 1 root root 66 Mar 8 14:09 etc drwxr-xr-x. 2 root root 6 Nov 3 2020 home lrwxrwxrwx. 1 root root 7 Nov 3 2020 lib -> usr/lib lrwxrwxrwx. 1 root root 9 Nov 3 2020 lib64 -> usr/lib64 drwx------. 2 root root 6 Sep 15 14:17 lost+found drwxr-xr-x. 2 root root 6 Nov 3 2020 media drwxr-xr-x. 2 root root 6 Nov 3 2020 mnt drwxr-xr-x. 2 root root 6 Nov 3 2020 opt dr-xr-xr-x. 265 root root 0 Mar 8 14:09 proc dr-xr-x---. 2 root root 162 Sep 15 14:17 root drwxr-xr-x. 11 root root 163 Sep 15 14:17 run lrwxrwxrwx. 1 root root 8 Nov 3 2020 sbin -> usr/sbin drwxr-xr-x. 2 root root 6 Nov 3 2020 srv dr-xr-xr-x. 13 root root 0 Mar 4 07:14 sys drwxrwxrwt. 7 root root 171 Sep 15 14:17 tmp drwxr-xr-x. 12 root root 144 Sep 15 14:17 usr drwxr-xr-x. 20 root root 262 Sep 15 14:17 var drwxr-xr-x. 2 root root 6 Mar 8 14:09 volume01 drwxr-xr-x. 2 root root 6 Mar 8 14:09 volume02
可以看见这俩行:(这就是我们刚才使用dockerfile 文件做的数据卷挂载)
drwxr-xr-x. 2 root root 6 Mar 8 14:09 volume01 drwxr-xr-x. 2 root root 6 Mar 8 14:09 volume02
看dockerfile 文件的内容:
FROM centos VOLUME ["volume01","volume02"] CMD echo "------end-----" CMD /bin/bash ~
可以看出,它是匿名挂载:
但凡是挂载,就是一定与外部有一个对应的目录
查看正在运行的容器
[root@localhost ~]# docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES b36bc0c1e4a9 d8e0f44b8da3 "/bin/bash" 14 minutes ago Up 14 minutes compassionate_brown 6590da464b6e nginx "/docker-entrypoint.…" About an hour ago Up About an hour 0.0.0.0:49154->80/tcp, :::49154->80/tcp nginx03 d8e9b9084cf8 nginx "/docker-entrypoint.…" 2 hours ago Up 2 hours 0.0.0.0:49153->80/tcp, :::49153->80/tcp nginx02 6d6fa6a4c6d7 5d0da3dc9764 "/bin/bash" 33 hours ago Up 33 hours nice_panini
看容器的系统信息
[root@localhost ~]# docker inspect b36bc0c1e4a9
这就是我们刚才数据卷挂载的位置
"Mounts": [
{
"Type": "volume",
"Name": "155842f6ab8581ad5d04fa25d6a1979647f481aad9532306834e577f88daa2a1",
"Source": "/var/lib/docker/volumes/155842f6ab8581ad5d04fa25d6a1979647f481aad9532306834e577f88daa2a1/_data",
"Destination": "volume01",
"Driver": "local",
"Mode": "",
"RW": true,
"Propagation": ""
},
{
"Type": "volume",
"Name": "1c6664c1368e4a11d36fd0b629c5e7b7d40d1d2f88322f9188383e92e52aa2f1",
"Source": "/var/lib/docker/volumes/1c6664c1368e4a11d36fd0b629c5e7b7d40d1d2f88322f9188383e92e52aa2f1/_data",
"Destination": "volume02",
"Driver": "local",
"Mode": "",
"RW": true,
"Propagation": ""
}
],
在容器内部新建一个文件
[root@b36bc0c1e4a9 /]# cd volume01 [root@b36bc0c1e4a9 volume01]# touch hsud.txt [root@b36bc0c1e4a9 volume01]#
看系统信息:
[root@localhost _data]# docker inspect b36bc0c1e4a9

在Linux主机上看容器中看
[root@localhost ~]# cd /var/lib/docker/volumes/155842f6ab8581ad5d04fa25d6a1979647f481aad9532306834e577f88daa2a1/_data [root@localhost _data]# ls hsud.txt [root@localhost _data]#
好了,这样我们就做好了,有关于使用Dockerfile实现数据卷的挂载就到这里了,谢谢大家了
您可能感兴趣的文章
- 12-20Kubernetes中使用临时容器进行故障排查的方法
- 12-20Nginx设置HTTPS的方法步骤
- 12-20二进制方式安装 Kubernetes1.18.3版本实现脚本
- 12-20Nginx工作模式及代理配置的使用细节
- 12-20ZooKeeper分布式协调服务设计核心概念及安装配置
- 12-20Kubernetes部署可视化地图的十个步骤
- 12-20关于docker清理Overlay2占用磁盘空间的问题(亲测有效)
- 12-20Docker compose配置文件写法及命令使用示例
- 12-20openwrt安装docker并启动的操作方法
- 12-20云原生Kubernetes初始化容器Init使用教程


阅读排行
推荐教程
- 12-07一文教你怎么选择Tomcat对应的JDK版本
- 12-07新版Eclipse集成Tomcat时找不到server选项的解决方法
- 12-06IIS7 应用程序池自动回收关闭的解决方案
- 12-05Windows Server 2019安装VMware
- 12-05Windows服务器默认IE浏览器无法下载文件的解决方法
- 12-05Docker安装Jenkins全过程
- 12-19Zabbix SAML SSO 登录绕过漏洞的操作流程
- 12-15Docker-Compose搭建Spark集群的实现方法
- 12-14Docker Desktop无法正常启动解决(failed to start...)
- 12-14k8s 与docker空间使用分析与清理方法





