容器挂载数据卷的几种情况

本文涉及的产品
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
容器镜像服务 ACR,镜像仓库100个 不限时长
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
简介: 挂载宿主机存在的【文件】到容器不存在的【文件】`宿主机存在文件:rainbow`$ cat rainbow This is my rainbow`运行容器`$ docker run -d -v $PWD/rainbow:$HOME/ra...
  • 挂载宿主机存在的【文件】到容器不存在的【文件】
`宿主机存在文件:rainbow`
$ cat rainbow 
This is my rainbow

`运行容器`
$ docker run -d -v $PWD/rainbow:$HOME/rainbow --name test_1 alpine tail -f /dev/null
38f19e99a0e00e67a605adc6e6b0b8d039bc78a49cb2491871ccf6fb761f564e

`容器内查看文件,挂载成功`
$ docker exec -it test_1 cat ~/rainbow 
This is my rainbow

  • 挂载宿主机存在的【文件】到容器存在的【文件】
`挂载本地环境变量到容器`
$ docker run -d -v /etc/profile:/etc/profile --name test_2 alpine tail -f /dev/null
x569cae718223b1d1f506c2d7a597d1a1b7fb13dceadab379bf4065d89ba9605846

`挂载成功,容器内的文件内容会被覆盖!`
$ docker exec -it test_2 cat ~/rainbow
...
  • 挂载宿主机不存在的【目录】到容器存在的【文件】
`容器启动失败`
$ docker run -d --name test_3 -v ~/test:/etc/apk/repositories alpine tail -f /dev/null
72b75e729dec991671daf54e4ed0985ba3c8fc93866066628446a697b64e2967
/usr/bin/docker-current: Error response from daemon: oci runtime error: container_linux.go:247: starting container process caused "process_linux.go:364: container init caused \"rootfs_linux.go:54: mounting \\\"/root/test\\\" to rootfs \\\"/var/lib/docker/overlay2/b989ba9605846a51027922c5656fb809c173b0617abcc0bb66
f8487ecbb22965/merged\\\" at \\\"/var/lib/docker/overlay2/b989ba9605846a51027922c5656fb809c173b0617abcc0bb66f8487ecbb22965/merged/etc/apk/repositories\\\" caused \\\"not a directory\\\"\""
: Are you trying to mount a directory onto a file (or vice-versa)? Check if the specified host path exists and is the expected type.

  • 挂载宿主机存在的【目录】到容器不存在的【目录】
`挂载本地jenkins_home目录到容器`
$ docker run -d --name test_4 -v /opt/jenkins_home:/var/jenkins_home alpine tail -f /dev/null
f709cae718223b1d1f506c2d7a597d1a1b7fb13dceadab379bf4065d982b462f

`挂载成功,容器内会自动新建此目录`
$ docker exec -it test_4 ls /var/jenkins_home
config.xml
copy_reference_file.log
hudson.model.UpdateCenter.xml
hudson.plugins.git.GitTool.xml
identity.key.enc
init.groovy.d
...

  • 挂载宿主机存在的【目录】到容器存在的【目录】
$ docker run -d --name test_5 -v /etc/cron.d:/etc/apk/ alpine tail -f /dev/null
b2c132e2f6cc3b7c726f6bfef9779543a8b031348cc2ba592353babacf781436

$ ls /etc/cron.d
0hourly

`挂载成功,容器内目录原内容被覆盖`
$ docker exec -it test_5 ls /etc/apk
0hourly

  • 挂载宿主机不存在的【目录】到容器不存在的【目录】
$ docker run -d --name test_6 -v ~/temp:/etc/temp alpine tail -f /dev/null
bd5c70a0f341ac1d4c6f6061ccb97c147e4ef9852835c4368aecc03d47c92572

`挂载成功,docker会自动在宿主机和容器内新建此目录`
$ docker exec -it test_6 ls /etc/temp
$ 

  • 挂载宿主机不存在的【目录】到容器存在的【目录】
$ docker run -d --name test_7 -v ~/test/:/etc/apk/ alpine tail -f /dev/null
a19443399641e3461155afe1b5bc410f913dc4ecfe2eb50b9bc652a48307b715

`挂载成功,容器内目录内容被覆盖(空)`
$ docker exec -it test_7 ls /etc/apk
$ 

  • 挂载宿主机存在的【文件】到容器存在的【目录】
`容器启动失败`
$ docker run -d --name test_8 -v /etc/profile:/etc/apk/ alpine tail -f /dev/null
2dda82d7d7312f132aa6930fe919375685dc2904e0ecad312e28d1274c9add4b
/usr/bin/docker-current: Error response from daemon: oci runtime error: container_linux.go:247: starting container process caused "process_linux.go:364: container init caused \"rootfs_linux.go:54: mounting \\\"/etc/profile\\\" to rootfs \\\"/var/lib/docker/overlay2/9205ea29badfcf3f49ffa1058797ce31ac6e750fbc1bd6a09598737958b5d478/merged\\\" at \\\"/var/lib/docker/overlay2/9205ea29badfcf3f49ffa1058797ce31ac6e750fbc1bd6a09598737958b5d478/merged/etc/apk\\\" caused \\\"not a directory\\\"\""
: Are you trying to mount a directory onto a file (or vice-versa)? Check if the specified host path exists and is the expected type.

  • 挂载宿主机存在的【目录】到容器存在的【文件】
`容器启动失败`
$ docker run -d --name test_10 -v ~/case/:/etc/apk/repositories alpine tail -f /dev/null
908c7bb8e387233733415a5da430526c5ddbe67775885d11014b607a31d07849
/usr/bin/docker-current: Error response from daemon: oci runtime error: container_linux.go:247: starting container process caused "process_linux.go:364: container init caused \"rootfs_linux.go:54: mounting \\\"/root/case\\\" to rootfs \\\"/var/lib/docker/overlay2/073f27fd5fe62ba821f178e2a5ac0137c197c16f9d5f5a73ce4e617eb80a3516/merged\\\" at \\\"/var/lib/docker/overlay2/073f27fd5fe62ba821f178e2a5ac0137c197c16f9d5f5a73ce4e617eb80a3516/merged/etc/apk/repositories\\\" caused \\\"not a directory\\\"\""
: Are you trying to mount a directory onto a file (or vice-versa)? Check if the specified host path exists and is the expected type.

总结

宿主机 容器 运行结果
文件存在 文件不存在 挂载成功
目录存在 目录不存在 挂载成功
------ ------ ------
文件存在 文件存在 挂载成功,容器内的文件内容被覆盖
目录存在 目录存在 挂载成功,容器内目录内容被覆盖
------ ------ ------
文件存在 目录存在 容器启动失败
目录存在 文件存在 容器启动失败
------ ------ ------
目录不存在 目录不存在 挂载成功,docker会自动在宿主机和容器内新建此目录
目录不存在 文件存在 容器启动失败
目录不存在 目录存在 挂载成功,容器内目录内容被覆盖(空)
相关文章
|
1月前
|
存储 Docker 容器
docker中挂载数据卷到容器
【10月更文挑战第12天】
76 5
|
2月前
|
移动开发 前端开发 HTML5
Twaver-HTML5基础学习(20)数据容器(3)_数据的批量加载(节省性能方法)
本文介绍了Twaver HTML5中数据的批量加载方法,通过使用`box.startBatch()`可以在大量数据加载时提高性能。文章通过示例代码展示了如何在React组件中使用批量加载功能,以减少界面重绘次数并提升效率。
57 2
Twaver-HTML5基础学习(20)数据容器(3)_数据的批量加载(节省性能方法)
|
2月前
|
XML 存储 JSON
Twaver-HTML5基础学习(19)数据容器(2)_数据序列化_XML、Json
本文介绍了Twaver HTML5中的数据序列化,包括XML和JSON格式的序列化与反序列化方法。文章通过示例代码展示了如何将DataBox中的数据序列化为XML和JSON字符串,以及如何从这些字符串中反序列化数据,重建DataBox中的对象。此外,还提到了用户自定义属性的序列化注册方法。
47 1
|
27天前
|
存储 缓存 Docker
docker中挂载数据卷到容器
【10月更文挑战第16天】
30 2
|
28天前
|
存储 关系型数据库 MySQL
|
29天前
|
存储 Docker 容器
docker中挂载数据卷到容器
【10月更文挑战第13天】
28 2
|
1月前
|
存储 测试技术 开发者
docker中将数据卷挂载到容器
【10月更文挑战第11天】
36 3
|
2月前
|
XML 移动开发 JSON
Twaver-HTML5基础学习(18)数据容器(1)_增删查改、遍历数据容器、包含网元判断
本文介绍了Twaver HTML5中的数据容器(DataBox),包括如何进行增删查改操作、遍历数据容器以及判断网元是否存在于数据容器中。DataBox用于管理所有的网元对象,如ElementBox、LayerBox、AlarmBox等,并通过示例代码展示了其常用方法的使用。
47 1
Twaver-HTML5基础学习(18)数据容器(1)_增删查改、遍历数据容器、包含网元判断
|
2月前
|
存储 索引 Python
python中的数据容器
python中的数据容器
|
1月前
|
存储 关系型数据库 MySQL