docker 的具名挂载与匿名挂载
大家好,今天我们分享一下docker 的具名挂载与匿名挂载以这条命令举例[root@localhost ~]# docker run -d -P --name nginx02-v /etc/nginx/nginxd8e9b9084cf884e7e0d11c560c3f50d94f2d4a2d9c77fccb3f52b5cfd8e55392[root@localhost ~]#这里我们就没有给它指定
大家好,今天我们分享一下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 权限说明命令只可以被宿主机操作,容器的内部将无法进行操作
平时不需要动它
好了,有关于docker 的具名挂载与匿名挂载就到这里了,谢谢大家
更多推荐
所有评论(0)