【docker系列】使用Volume方式挂载容器数据卷

一、创建Volume

使用docker volume create创建一个Volume数据卷,命令参数为数据卷的名称。

# docker volume create nginx-html
nginx-html

查看当前服务器docker引擎下所有的命名数据卷

# docker volume ls
DRIVER    VOLUME NAME
local     nginx-html

通过docker volume inspect <数据卷名称>查看该数据卷的信息,核心信息是Mountpoint表示该数据卷在宿主机上的文件路径。

# docker volume inspect nginx-html
[
    {
        "CreatedAt": "2022-04-05T08:32:19+08:00",
        "Driver": "local",
        "Labels": {},
        "Mountpoint": "/var/lib/docker/volumes/nginx-html/_data",
        "Name": "nginx-html",
        "Options": {},
        "Scope": "local"
    }
]

这时我们可以去宿主机路径"/var/lib/docker/volumes/nginx-html/_data"看一下,里面什么文件都没有,是个空目录。

二、使用Volume

启动nginx容器,注意-v的映射关系是宿主机nginx-config(Volume)到容器内/usr/share/nginx/html路径的映射,实际上就是宿主机文件目录/var/lib/docker/volumes/nginx-html/_data到容器内/usr/share/nginx/html路径的映射。

docker run -d --name volume-nginx \
  -p 80:80 \
  -v nginx-html:/usr/share/nginx/html/  \
  nginx:latest

容器启动之后,我们再去看一下"/var/lib/docker/volumes/nginx-html/_data"路径,我们发现这个路径下多出来一些文件,都是nginx默认的html文件。

这就是Volumes的好处:

  • 在容器第一次启动的时候,它会将容器内的映射路径下的文件复制到宿主机上保存,不用我们自己手动的docker cp
  • 一旦我们在宿主机上修改了这些文件,容器运行时就以宿主机上的文件为准。可以回头去看一下《示例-docker安装nginx》那一篇我们没有事先创建Volume的情况下,我们是怎么做的

如何销毁Volume? 销毁Volume的前提是没有容器使用它,可以使用docker volume rm命令进行删除。

三、volumes与Bind Mount的区别

不同点volumesbind mounts
Source位置/var/lib/docker/volumes/…可以任意指定
对已有挂载点影响在容器第一次启动的时候,容器内映射目录的数据复制到volume宿主机路径下的文件,覆盖掉容器内挂载路径文件的内容
是否支持单个文件映射不支持,只能是目录支持
权限控制读写或者只读读写或者只读
移植性强,无需指定宿主机文件目录,默认在/var/lib/docker/volumes/目录下弱,与宿主机绝对路径强绑定

3.1.关于volumes移植性强的解释

假设我们现在有一百台服务器,我们希望nginx容器在任何一台服务器上启动都使用同样的配置,达到同样的运行效果,该怎么做?

  • 如果是Bind Mount,Source文件路径你可以随意指定、随意命名。如果想达到一定的规范度,只能从制度上进行规范,在技术上很难限制。
  • 如果是volumes,运维人员创建的Volume只要名称是一致的,就可以认为文件路径是一致的,默认统一的放在/var/lib/docker/volumes/目录下。假如某天某个服务器/var/lib/docker磁盘空间不足,我们只需要重新挂载一个服务器硬盘,将/var/lib/docker的文件及目录整体迁移至新硬盘的新路径即可,修改docker默认存储路径为新路径,就对于容器的运行没有任何影响。

3.2.如何修改docker默认存储路径/var/lib/docker

vim /etc/docker/daemon.json ,添加如下内容:

{
"data-root": "/data/docker"
}

文件修改之后,重启docker引擎(需要注意的是:修改默认存储路径,如果你不希望原始的镜像及容器、数据卷等丢失,请先进行数据迁移。)

systemctl daemon-reload
systemctl restart docker
<think>嗯,用户想了解如何在Docker中创建容器挂载数据卷。首先,我需要回忆Docker的基本命令,特别是docker run的用法。记得数据卷挂载有两种方式:具名挂载和匿名挂载,还有直接挂载主机目录。 用户可能需要具体的示例,所以得举几个例子。比如,挂载主机目录到容器使用-v参数。比如docker run -v /宿主机路径:/容器路径。这时候要确保路径正确,特别是Windows和Linux的路径差异可能需要说明。 然后,具名挂载的例子,使用具名卷,比如创建一个名为my_volume的卷,然后挂载容器里。这时候可能要用到docker volume create命令,不过其实docker run的时候如果卷不存在会自动创建,所以可能不需要手动创建。需要提到docker volume inspect来查看卷的详细信息,这样用户知道如何检查挂载情况。 匿名挂载的话,只需要指定容器内的路径,宿主机路径由Docker自动生成,但可能不太方便管理,所以通常推荐具名挂载。不过还是应该提到,让用户了解区别。 另外,数据卷容器也是一个概念,可以通过--volumes-from来共享卷。比如创建一个数据卷容器,然后其他容器挂载它的卷。这个可能在多个容器需要共享数据时有用,比如备份或者多个服务访问同一数据。 用户可能还关心如何验证挂载是否成功,可以在容器内创建文件,然后在宿主机查看是否存在,或者用docker inspect命令查看挂载点。 还要注意权限问题,有时候容器内的用户可能没有写权限,导致挂载的目录不可写,这时候可能需要设置权限或者使用特权模式,但这里可能不需要深入,除非用户提问。 安全问题方面,挂载主机目录可能会有风险,特别是挂载系统目录,需要提醒用户注意。 可能还需要提到数据卷的作用,比如持久化数据,避免容器删除后数据丢失,这样用户理解为什么需要挂载数据卷。 最后,给出具体的命令示例,分步骤说明,这样用户可以直接复制粘贴使用。同时,引用中的docker volume inspect和docker run命令需要对应上,确保示例准确。</think>### Docker 容器创建与数据卷挂载教程 #### 1. **基础命令格式** Docker 创建容器挂载数据卷的核心命令为: ```bash docker run -v [宿主机路径|卷名]:[容器路径] [其他参数] [镜像名] ``` 通过 `-v` 参数实现目录挂载,支持三种形式: - **主机目录挂载**:直接绑定宿主机目录 - **具名挂载**:使用预定义的数据卷名称 - **匿名挂载**:自动生成随机卷名 --- #### 2. **操作示例** **场景1:主机目录挂载** ```bash docker run -d --name nginx-web \ -v /home/user/nginx/html:/usr/share/nginx/html \ -p 80:80 \ nginx ``` - **验证挂载**: ```bash # 宿主机创建文件 touch /home/user/nginx/html/test.txt # 进入容器检查 docker exec nginx-web ls /usr/share/nginx/html ``` **场景2:具名挂载** ```bash # 创建数据卷(可省略,Docker会自动创建) docker volume create app-data # 启动容器 docker run -d --name mysql-db \ -v app-data:/var/lib/mysql \ -e MYSQL_ROOT_PASSWORD=123456 \ mysql:8.0 ``` - **查看卷信息**: ```bash docker volume inspect app-data ``` 输出显示挂载点路径(如 `/var/lib/docker/volumes/app-data/_data`)[^1] **场景3:匿名挂载** ```bash docker run -d --name temp-storage \ -v /app/config \ alpine ``` - **查看匿名卷**: ```bash docker volume ls ``` --- #### 3. **数据卷容器共享** ```bash # 创建数据卷容器 docker create --name volume-container \ -v /shared-data \ busybox # 其他容器共享数据 docker run -d --name app1 \ --volumes-from volume-container \ nginx docker run -d --name app2 \ --volumes-from volume-container \ nginx ``` --- #### 4. **关键注意事项** 1. **路径规范**: - Windows 路径使用 `//C/Users` 格式 - 容器内路径需为绝对路径 2. **权限控制**: - 添加 `:ro` 限制容器只读(如 `-v data:/app:ro`) 3. **数据持久化**: - 容器删除后,具名/匿名卷会保留,需手动清理: ```bash docker volume rm [卷名] docker volume prune # 清理未使用卷 ``` ---
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

字母哥哥

您的支持是我不竭的创作动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值