Docker教程小白实操入门(20)--如何删除数据卷

一、需求

如何删除一个容器对应的数据卷

 

二、数据卷和容器时独立的

  • 数据卷是被设计用来持久化数据的,它的生命周期独立于容器,如果在创建容器时挂载了数据卷,执行docker rm删除容器时,并不会自动地将容器对应的数据卷删除掉。
  • Docker中也不存在垃圾回收这样的机制来处理没有任何容器引用的数据卷。

 

三、如果知道想要删除的数据卷的名字

docker volume rm volumeName

只会尝试地去删除数据卷,如果该数据卷还被容器使用,那么将删除不成功。

 

四、删除容器时如果想要将容器对应的数据卷也同时删除掉

docker rm -v containerId|containerName

只会尝试地去删除容器对应的数据卷,如果该数据卷还被其他容器使用,那么将删除不成功。

 

1. 没有显式指定数据卷名

如果是docker run -v /data --name container1 ubuntu创建的数据卷(没有显示指定数据卷名),如果该数据卷没有被其他任何容器使用,那么在使用docker rm -v container1尝试删除container1容器以及对应的数据卷时,会把数据卷删除掉。

2. 显式指定数据卷名

如果用docker run -v vo1:/data --name container1 ubuntu创建的数据卷(显示指定数据卷名),也就是创建时指定了“数据卷名”,那么在使用docker rm -v container1尝试删除容器以及对应的数据卷时,不会将数据卷删除,只是解除了数据卷和容器的联系。如果要删除数据卷,还得在上述基础上,继续使用docker volume rm vo1

 

五、在创建容器时指定--rm标签

如果在创建容器时指定了--rm标签,那么在容器处于“终止状态”时就会删除容器以及尝试删除容器所对应的数据卷。当然在删除容器对应的数据卷时,如果没有指定了数据卷名,那么将删除对应的数据卷。如果指定了数据卷名,也只是解除了数据卷和容器的联系,真正要删除,还得执行docker volume rm

 

六、删除无用的数据卷

在我们的工作中难免在删除容器时忘记删除了数据卷,当然我们可以通过docker volume rm一条条地尝试的去删除。但是docker提供了更加简便的方法。也就是:

# 将所有没有被容器使用的数据卷删除掉
docker volume prune

 

七、实例

#!/bin/bash
#创建一个名为container1的容器,创建一个数据卷挂载到容器的/data目录
#拉取ubutun 最新镜像,实际生产中,docker pull 这一步可以省略,docker run的时候会自己去拉取。
docker pull ubuntu

docker run -v vo4:/data --name container1 ubuntu
#删除container1对应的数据卷
#********** Begin *********#
# 解除容器和数据卷关系
docker rm -v container1
# 删除数据卷
docker volume rm vo4
#********** End **********#

 

 

 

 

参考:https://www.educoder.net/shixuns/pebvjtk9/challenges

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,关于 Docker 数据卷的进阶篇,我可以为你提供以下内容: 1. 数据卷的类型 Docker 数据卷有三种类型:主机挂载、匿名卷、命名卷。其中,主机挂载是将主机上的目录挂载到容器中;匿名卷是在容器内部创建的临时卷;命名卷则是给卷起一个名字,并将其保存在 Docker 数据卷存储区中。 2. 数据卷的备份与恢复 我们可以使用 Docker Compose 中的 `docker-compose.yml` 文件来定义数据卷的备份和恢复。具体方法是,在 `volumes` 字段中定义卷及其备份路径,然后在 `services` 字段中指定容器和对应的卷名称。 例如: ``` version: "3" services: db: image: mysql volumes: - db_data:/var/lib/mysql command: --default-authentication-plugin=mysql_native_password backup: image: backup volumes: - /path/to/backup:/backup - db_data:/data/db command: backup.sh volumes: db_data: ``` 以上代码中,我们定义了一个 `db` 服务和一个 `backup` 服务。其中,`db` 服务使用了名为 `db_data` 的命名卷,并挂载到容器的 `/var/lib/mysql` 目录中;`backup` 服务则使用了两个卷,一个是挂载到宿主机上的 `/path/to/backup` 目录,用于保存备份文件;另一个是使用了 `db_data` 命名卷,并挂载到容器的 `/data/db` 目录中,用于备份数据。最后,我们在 `backup` 服务中执行了备份脚本 `backup.sh`。 3. 数据卷的共享 我们可以将一个数据卷挂载到多个容器中,实现数据的共享。例如,我们可以将一个命名卷挂载到 `web` 和 `db` 两个服务中,这样它们就可以共享数据了。 ``` version: "3" services: web: image: nginx volumes: - web_data:/usr/share/nginx/html db: image: mysql volumes: - db_data:/var/lib/mysql - web_data:/var/www/html volumes: db_data: web_data: ``` 以上代码中,我们定义了一个 `web` 服务和一个 `db` 服务。其中,`web` 服务使用了名为 `web_data` 的命名卷,挂载到容器的 `/usr/share/nginx/html` 目录中;`db` 服务则使用了 `db_data` 和 `web_data` 两个卷,分别挂载到容器的 `/var/lib/mysql` 和 `/var/www/html` 目录中,实现了数据的共享。 希望以上内容能够对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

软件工程小施同学

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

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

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

打赏作者

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

抵扣说明:

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

余额充值