docker数据卷持久化数据

  1. 什么是Docker数据卷
  2. 创建数据卷
  3. 挂载数据卷
  4. 管理数据卷
  5. 挂载主机目录

1. 什么是Docker数据卷

在Docker容器化的环境中,数据的持久性是一个常见的挑战。当容器被删除或重新创建时,容器内的数据通常会丢失。为了解决数据不随容器丢失的问题,Docker提供了数据卷的功能,可以实现数据的持久化和共享。本文将介绍如何使用Docker数据卷来实现数据的持久化。

Docker数据卷是一个特殊的目录,它可以绕过容器文件系统的生命周期,使数据在容器之间保持一致和持久化。数据卷可以在容器之间共享,并且它们的内容可以在多个容器之间保持一致。我们可以将主机的目录或者使用Docker管理的命名卷挂载到容器中,从而实现数据的持久化。

2. 创建数据卷

自动创建 :在运行容器时使用 -v--volume 选项指定一个未存在的数据卷名,Docker会自动创建一个新的数据卷并将其挂载到容器内。

bash 复制代码
docker run -v my_volume:/path/in/container image_name


➜  ~ docker run -dP --name nginx -v hello:/root nginx
d51d3414df425cc8ee1a0abe874dbbe0786aedd2650b4aad2df96dab1ab05825
➜  ~ docker volume ls
DRIVER    VOLUME NAME
local     hello

会创建一个命名为hello的数据卷,挂载到nginx容器内的/root目录。挂载路径根据实际需要设置,当有多个容器路径需要数据集时,可以挂载多个数据卷,每一个需要挂载挂载一个数据卷,-v hello:/root -v hello2:/home

手动创建 :使用 docker volume create 命令创建一个数据卷,然后在运行容器时指定使用。

javascript 复制代码
docker volume create my_volume
docker run -v my_volume:/path/in/container image_name

3. 挂载数据卷

挂载到容器 :在 docker run 命令中使用 -v--volume 选项指定数据卷名和容器内挂载点。

javascript 复制代码
docker run -v my_volume:/path/in/container image_name

4. 管理数据卷

  • 查看数据卷 :使用 docker volume ls 列出所有数据卷。
  • 查看数据卷详情 :使用 docker volume inspect <volume_name> 查看指定数据卷的详细信息。
  • 删除数据卷 :使用 docker volume rm <volume_name> 删除不再需要的数据卷。注意,删除数据卷会永久删除其中的数据,操作前请确保已备份重要数据。
  • 删除未使用的数据卷 :使用docker volume prune删除未被容器使用的数据卷,谨慎使用。

5. 挂载主机目录

Docker还提供了命名卷的功能,可以在多个容器之间共享和重用。我们可以使用以下命令来创建一个命名卷:

bash 复制代码
docker run -d -v /host/path:/path/to/container/directory <image>


➜  ~ docker run -dP --name nginx -v ${PWD}/nginx:/root ngi
nx
867afa7f98ce3b980817ebe4facfa7d0b7a290290ea11f416962958303edfcf6
➜  ~ echo "Hello World" > ~/nginx/hello.txt
➜  ~ docker exec 867afa cat /root/hello.txt
Hello World

创建了一个nginx容器,将宿主机的当前目录下/nginx挂载到容器内/root,输出Hello Wolrd 到 /root/hello.txt。接下来打印容器内/root/hello.txt,打印出Hello World,说明我们操作宿主机的目录,容器内中也产生了变化。

${PWD}是当前工作目录的简写,也可以写目录的绝对路径,效果一致。

综上所述,Docker数据卷为容器提供了持久化、可共享的数据存储空间,是构建健壮、可维护的容器化应用不可或缺的一部分。通过合理使用数据卷,可以有效管理容器数据,确保数据的安全性与可用性,方便数据的备份与迁移。

忍不住要加个关注!不是我吹,但你会后悔没关注的!

相关推荐
gs801401 小时前
网络隐形杀手:从 Could not connect to SMTP host 报错深度剖析 Docker MTU 黑洞理论与实战
网络·docker·容器
程序猿阿伟2 小时前
《一套完整方法论:搞定图形应用的Docker镜像优化》
数据库·docker·容器
java_logo2 小时前
2026 Docker 国内镜像加速配置教程
运维·docker·容器·docker镜像·docker镜像源·docker镜像加速·docker镜像国内库
IT策士3 小时前
Docker从0到1再到 Kubernetes 实战:第15篇Compose 中的服务依赖、健康检查与启动顺序
docker·容器·kubernetes
“码”力全开3 小时前
深度解析:基于 Docker 与边缘计算的 AI 视频管理平台架构——打通 GB28181/RTSP 协议与“源码交付”的高效集成方案
人工智能·docker·边缘计算
顾默@3 小时前
双系统Ubuntu18.04升级22.04,安装docker进行openclaw安装
运维·docker·容器
木卫二号Coding3 小时前
打包容器有两种方式
docker
蜀道山老天师4 小时前
Docker Compose 多容器编排实战:LNMP、Tomcat 集群、云桌面、Portainer、Zabbix 一键部署
运维·docker·容器·tomcat·zabbix
“码”力全开5 小时前
解构企业级安防中台:基于Docker容器化与GB28181/RTSP多协议汇聚的边缘计算AI视频管理平台(全量源码交付)
人工智能·docker·边缘计算
见牛羊6 小时前
docker理解
java·docker·容器