Docker数据管理(数据卷)

docker在容器中管理数据主要有两种方式:

  • 数据卷(Volumes)

  • 挂载主机目录(Bind mounts)

数据卷

为了很好的实现数据保存和数据共享,Docker提出了Volume这个概念,简单的说就是绕过默认的联合文件系统,而以正常的文件或者目录的形式存在于宿主机上。又被称作数据卷。

数据卷 是一个可供一个或多个容器使用的特殊目录,它绕过 UFS,可以提供很多有用的特性:

数据卷 可以在容器之间共享和重用

对 数据卷 的修改会立马生效

对 数据卷 的更新,不会影响镜像

数据卷 默认会一直存在,即使容器被删除

创建数据卷

docker volume create my-vol

查看所有数据卷

docker volume ls

删除一个 volume

docker volume rm my-vo l

创建并进入容器

docker run -it --name c1 centos

创建容器并后台运行

docker run -itd --name c2 centos

删除所有容器包括在运行的容器

docker rm -f $(docker ps -aq)

挂载数据卷

在用 docker run 命令的时候,使用 --mount 标记来将 数据卷 挂载到容器里。在一次 docker

run 中可以挂载多个 数据卷 。

docker run -itd \

--name 容器名字 \

--mount source=数据卷名称,target=容器中的对应目录 \

镜像名称

查看数据卷的具体信息

docker inspect 数据卷名字

挂载目录

挂载之前必须保证该目录存在,否则挂载失败(宿主机目录)

方法一

docker run -it \

--name c2 --mount \

type=bind,source=/usr/local/java,target=/aa centos

方法二

Docker run -it \

--name c2 \

-v /usr/local/java:/aa \

Centos

创建数据卷容器

docker run -itd --name name -v dir centos

挂载数据卷容器

docker run -itd --name name --volumes-from db_data centos

相关推荐
地下核武7 分钟前
Ubuntu 26.04 “星际之门”(Luminous) 发布全解析
linux·运维·ubuntu
暂未成功人士!9 分钟前
在windows电脑上的vscode使用sftp将项目文件与嵌入式平台(Ubuntu)同步的方法
linux·运维·vscode·ubuntu·ssh
Amnesia0_016 分钟前
linux中的git和gdb
linux·运维·git
浅念-20 分钟前
Linux 进程与操作系统
linux·运维·服务器·网络·数据结构·笔记·网络协议
开开心心就好25 分钟前
桌面图标乱了怎么办,一键恢复固定位置工具
运维·服务器·windows·pdf·excel·3dsmax·houdini
zb2006412030 分钟前
自己编译RustDesk,并将自建ID服务器和key信息写入客户端
运维·服务器
Agent产品评测局33 分钟前
企业采购自动化落地,供应商全生命周期管控实现方案:智能体驱动下的全链路提效与合规治理
运维·人工智能·ai·chatgpt·自动化
2601_949814171 小时前
docker离线安装及部署各类中间件(x86系统架构)
docker·中间件·系统架构
桌面运维家1 小时前
KVM虚拟机:存储IO瓶颈诊断与Linux性能优化实战
linux·运维·性能优化
得物技术1 小时前
日志诊断 Skill:用 AI + MCP 一键解决BUG|得物技术
运维·后端·程序员