docker的具名挂载与匿名挂载实现

本站所有内容来自互联网收集,仅供学习和交流,请勿用于商业用途。如有侵权、不妥之处,请第一时间联系我们删除!Q群:迪思分享

免费资源网 – https://freexyz.cn/

大家好,今天我们分享一下docker 的具名挂载与匿名挂载

以这条命令举例

[root@localhost ~]# docker run -d -P –name nginx02 -v /etc/nginx/ nginx d8e9b9084cf884e7e0d11c560c3f50d94f2d4a2d9c77fccb3f52b5cfd8e55392 [root@localhost ~]#

这里我们就没有给它指定端口: 它对应的外网端口是随即的

查看一下正在运行的容器:

[root@localhost ~]# docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES d8e9b9084cf8 nginx “/docker-entrypoint.…” 11 minutes ago Up 11 minutes 0.0.0.0:49153->80/tcp, :::49153->80/tcp nginx02 6d6fa6a4c6d7 5d0da3dc9764 “/bin/bash” 32 hours ago Up 32 hours nice_panini [root@localhost ~]#

对应的外网端口是49153

我们可以使用浏览器上访问:http://192.168.1.12:49153

docker的具名挂载与匿名挂载实现插图

这是docker数据卷命令的帮助:

[root@localhost ~]# docker volume –help Usage: docker volume COMMAND Manage volumes Commands: create Create a volume inspect Display detailed information on one or more volumes ls List volumes prune Remove all unused local volumes rm Remove one or more volumes Run docker volume COMMAND –help for more information on a command.

这些都是匿名的挂载 ,因为没有给它起名字

DRIVER VOLUME NAME local 3f0cc224bb62dceae38c25d6eaee76512b39ec786590099f4b2930674640756f local 8e16818bb95e740e59e5ef920e54751eb64db44f4cf43841a9c45aa6ad6646cc local 686e9b7764c19581aea3107940fc28c68121759ce28b31fabc0fce00659ff7ca local 882c0d1810e3ac6fddabcff2c65f1022605f450a6c49504edf57e78de14da1e5 local 1490f17c760b935d926fb1fedc7de4e0e07f1084fcf8c769c672d50f43757f8f local 471762be4837d40ad175b7cfe74b81a51b4b3e752cb6f15e7e79d09ffc5f65fc local af4dc486d8335ec0e524c0e30a0ae037ef05dfa7a4ed3e4e0dd59954c5084a9e local c26b0f08ebdb140d91cb450313e9e314239c1c3553a612e6534154006aa19744 local c52728c97a7ee672216ccb2d4392fa83bc480dd9646ddb5577e1124eb98e15b6

这里写一个具名挂载

[root@localhost ~]# docker run -d -P –name nginx02 -v juming-nginx:/etc/nginx nginx

看最后的一行,就是具名挂载

[root@localhost ~]# docker volume ls DRIVER VOLUME NAME local 3f0cc224bb62dceae38c25d6eaee76512b39ec786590099f4b2930674640756f local 8e16818bb95e740e59e5ef920e54751eb64db44f4cf43841a9c45aa6ad6646cc local 686e9b7764c19581aea3107940fc28c68121759ce28b31fabc0fce00659ff7ca local 882c0d1810e3ac6fddabcff2c65f1022605f450a6c49504edf57e78de14da1e5 local 1490f17c760b935d926fb1fedc7de4e0e07f1084fcf8c769c672d50f43757f8f local 471762be4837d40ad175b7cfe74b81a51b4b3e752cb6f15e7e79d09ffc5f65fc local af4dc486d8335ec0e524c0e30a0ae037ef05dfa7a4ed3e4e0dd59954c5084a9e local c26b0f08ebdb140d91cb450313e9e314239c1c3553a612e6534154006aa19744 local c52728c97a7ee672216ccb2d4392fa83bc480dd9646ddb5577e1124eb98e15b6 local juming-nginx

显示数据卷的具体信息

[root@localhost ~]# docker volume inspect juming-nginx [ { “CreatedAt”: “2022-03-05T18:16:53+08:00”, “Driver”: “local”, “Labels”: null, “Mountpoint”: “/var/lib/docker/volumes/juming-nginx/_data”, “Name”: “juming-nginx”, “Options”: null, “Scope”: “local” } ]

docker 容器中所有的卷,在没有指定目录的情况下,都在var/lib/docker/volumes/juming-nginx/_data”,

我们可以通过具名挂载找到卷的位置,大多数情况下,我们使用具名挂载

关于docker的挂载问题,有三个比较容易混淆的概念: (区分的方式)

1.具名挂载:-v 参数 卷名:容器内路径

2.匿名挂载:-v 参数后面 没有写上容器之外的地址, docker 自己会在docker内部给你找个位置

3.指定路径挂载: -v /宿主机路径::容器内路径

这里有一个权限问题:

[root@localhost ~]# docker run -d -P –name nginx03 -v juming-nginx:/etc/nginx:rw nginx 6590da464b6ea5cecf58f1cfcdfe2df35092383adb7aaddac4ca5d463367c979

rw :可读可写的权限

ro : 可读权限[root@localhost ~]# docker run -d -P –name nginx03 -v juming-nginx:/etc/nginx:ro nginx

这个会对我们挂载出来的内容进行限定

ro 权限说明命令只可以被宿主机操作,容器的内部将无法进行操作

平时不需要动它

免费资源网 – https://freexyz.cn/


© 版权声明
THE END
★喜欢这篇文章吗?喜欢的话,麻烦动动手指支持一下!★
点赞6 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容