docker具名挂载与匿名挂载
思诚代码块 人气:1大家好,今天我们分享一下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数据卷命令的帮助:
[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 权限说明命令只可以被宿主机操作,容器的内部将无法进行操作
平时不需要动它
加载全部内容