Docker之路(6.docker容器数据卷、具名挂载匿名挂载、权限挂载)

文章介绍了Docker容器数据卷的概念,用于在容器删除后保留数据,并实现容器间的数据共享。通过挂载主机目录到容器内实现数据持久化,同时展示了如何创建和使用数据卷,包括具名挂载、匿名挂载以及读写权限的设定。此外,还提到了多个容器间的数据共享方法——`volumes-from`参数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. 什么是容器数据卷

如果数据都在容器中,那么容器删除后,数据就会丢失!
所以希望容器的数据能够存到本地
容器之间可以又一个数据共享的技术!
Docker容器中产生的数据,可以同步到本地,这就是卷技术。
就是将我们容器内的目录,挂载到Linux上面。
即就是容器的持久化和同步操作!容器间也是可以数据共享的!

好处:以后只需要在本地修改即可,容器内会自动同步

2. 使用数据卷

我们准备一个 centos 的docker容器,来使用数据卷

2.1 拉取一个 centos 镜像

docker pull centos

2.2 启动镜像并挂载目录

  1. 启动镜像,并进入容器中,在容器中的home目录下创建docker_test文件夹
docker run -it centos /bin/bash

cd /home/
mkdir docker_test
  1. 退出镜像,ctrl+P+Q
  2. 在主机的home目录下创建test文件下
cd /home/
mkdir test
  1. 停止容器
docker stop 容器id
  1. 再次启动镜像并进入容器,并映射挂载目录,让主机的/home/test映射到容器中的/home/docker_test
docker run -it -v /home/test:/home/docker_test centos /bin/bash


# 例如:挂载mysql
docker run -d -p 3310:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 mysql:5.7

注意的是:主机目录会直接覆盖掉容器中要挂载的目录

  1. 退出镜像,ctrl+P+Q,查看是否映射上去
docker inspect 容器id



"Mounts": [                                           # 挂载
    {
        "Type": "bind",
        "Source": "/home/test",                       # 主机内的地址
        "Destination": "/home/docker_test",           # docker容器内的地址
        "Mode": "",
        "RW": true,
        "Propagation": "rprivate"
    }
],

在这里插入图片描述

2.3 测试挂载的目录是否是同步的

  1. 我们在主机的/home/test文件夹下创建一个a.py
cd /home/test
touch a.py

在这里插入图片描述

  1. 然后进入到容器中,查看映射到容器的目录 /home/docker_test 下同步会有一个a.py文件
docker exec -it 容器id /bin/bash

cd /home/docker_test
ls

在这里插入图片描述

注意:如果该容器是不是运行中,但是已经做过挂载的,也是可以目录也是可以同步的

3. 具名挂载和匿名挂载

-v 容器内路径                # 匿名挂载
-v 卷名:容器内路径            # 具名挂载
-v /宿主机路径:容器内路径      # 指定路径挂载 

4. 挂载时,指定读写权限

-v 容器内路径:ro/rw  改变读写权限

ro: readonly    # 只读
rw: readwrite   # 可读可写

设置了容器权限,容器对我们挂载出来的内容就有限定了!
只要看到ro,说明这个路径只能通过宿主机改变

docker run -d -P --name nginx01 -v juming-nginx01:/etc/nginx:ro nginx
docker run -d -P --name nginx02 -v juming-nginx02:/etc/nginx:rw nginx

4. 多个容器互相数据共享 --volumes-form

  • 例如: 多个mysql实现数据共享
docker run -d p 3310:3306 -v /etc/mysql/conf.d -v /var/lib/mysql -e 
MYSQL_ROOT_PASSWORD=123456 -- name mysql:5.7

docker run -d p 3310:3306 -e MYSQL_ROOT_PASSWORD=123456 -- name mysql:5.7
--volumes-form mysql01 mysql:5.7

容器之间配置信息的传递,容器数据卷的生命周期一直持续到没有容器被使用为止。
但是一旦持久化到了本地之后,这时候,本地的数据是不会删除的

<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 # 清理未使用卷 ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

还是那个同伟伟

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值