【Docker篇】数据卷相关操作

文章目录

🎈前言

在前面文章的nginx案例中,修改nginx的html页面时,需要进入nginx内部。并且因为没有编辑器,修改文件也很麻烦。

这就是因为容器与数据(容器内文件)耦合带来的后果。

我们可以使用数据卷来解决这个问题

🍔数据卷

数据卷(Data Volume)是在容器化环境中用于持久化存储数据的一种机制。它可以在容器和主机之间共享和存储数据,以便容器可以在重新启动或迁移后保留数据状态。

数据卷提供了一个独立于容器的文件系统,它可以被一个或多个容器挂载和访问。是一个虚拟目录,指向宿主机文件系统中的某个目录。这意味着即使容器被删除或重启,数据卷中的数据仍然存在。数据卷可以包含文件、目录或整个文件系统。

将容器与数据分离,解耦合,方便操作容器内数据,保证数据安全

一旦完成数据卷挂载,对容器的一切操作都会作用在数据卷对应的宿主机目录了。

这样,我们操作宿主机的/var/lib/docker/volumes/html目录,就等于操作容器内的/usr/share/nginx/html目录了

🛸操作命令

基本语法

docker volume [COMMAND]

docker volume命令是数据卷操作,根据命令后跟随的command来确定下一步的操作:

  • create 创建一个volume
  • inspect 显示一个或多个volume的信息
  • ls 列出所有的volume
  • prune 删除未使用的volume
  • rm 删除一个或多个指定的volume

⭐创建一个数据卷,并查看数据卷在宿主机的目录位置


创建数据卷

bash 复制代码
docker volume create html

查看所有数据

查看数据卷详细内容

可以看到,我们创建的html这个数据卷关联的宿主机目录为/var/lib/docker/volumes/html/_data目录。

🌹挂载数据卷

挂载数据卷在容器化环境中有以下几个用途和好处:

数据持久性:通过将数据卷挂载到容器中,可以将数据存储在主机上的持久存储介质中,使得即使容器被删除或重启,数据仍然保留。这对于需要长期保存数据的应用程序非常重要。

数据共享:多个容器可以通过挂载同一个数据卷来共享数据。这可以实现容器之间的数据交换和共享状态,提高协作和数据一致性。例如,多个容器可以共享配置文件、日志文件、数据库文件等。

数据备份和恢复:通过挂载数据卷,可以方便地进行数据备份和恢复操作。可以定期备份数据卷,以防止数据丢失或损坏,并在需要时恢复数据到先前的状态。

数据迁移:数据卷的挂载可以实现容器和主机之间的数据迁移。当需要在不同的环境或主机之间迁移容器时,可以将数据卷挂载到新的容器中,以保留原有的数据和状态。


我们在创建容器时,可以通过 -v 参数来挂载一个数据卷到某个容器内目录,命令格式如下:

bash 复制代码
docker run \
  --name mn \
  -v html:/root/html \
  -p 8080:80
  nginx \

这里的-v就是挂载数据卷的命令:

  • -v html:/root/htm :把html数据卷挂载到容器内的/root/html这个目录中

在技术的道路上,我们不断探索、不断前行,不断面对挑战、不断突破自我。科技的发展改变着世界,而我们作为技术人员,也在这个过程中书写着自己的篇章。让我们携手并进,共同努力,开创美好的未来!愿我们在科技的征途上不断奋进,创造出更加美好、更加智能的明天!

相关推荐
程序员 小柴3 分钟前
docker的与使用
java·docker·eureka
ghostwritten19 分钟前
Docker Registry Clean
运维·docker·容器
niuniu_66635 分钟前
简单的自动化场景(以 Chrome 浏览器 为例)
运维·chrome·python·selenium·测试工具·自动化·安全性测试
宋冠巡1 小时前
Windows安装Docker(Docker Desktop)
windows·docker·容器
这儿有一堆花2 小时前
Kali Linux 2025.1a:主题焕新与树莓派支持的深度解析
linux·运维·服务器
wanhengidc2 小时前
算力服务器和普通服务器之间的不同之处
运维·服务器
阿噜噜小栈2 小时前
最新国内可用的Docker镜像加速器地址收集
运维·笔记·docker·容器
云上艺旅2 小时前
K8S学习之基础六十八:Rancher创建deployments资源
学习·云原生·容器·kubernetes·rancher
rider1892 小时前
【4】搭建k8s集群系列(二进制部署)之安装master节点服务(kube-apiserver)
云原生·容器·kubernetes
海鸥814 小时前
podman和与docker的比较 及podman使用
docker·容器·podman