Docker三 | 数据卷

目录

Docker数据卷简介

添加数据卷的命令

容器数据卷的继承


Docker数据卷简介

Docker容器产生的数据,如果不备份,当容器实例删除后,容器中的数据也会消失,为了保存数据可以在Docker中使用数据卷。Docker数据卷是宿主机的一个可以供一个或多个容器使用的特殊目录,它可以在容器之间共享和重用,使得本地与容器间传递数据更高效。对数据卷的修改会立马生效,在容器内部与本地目录均可对数据卷进行修改。

添加数据卷的命令

bash 复制代码
docker run -it --privileged=true -v /宿主机绝对路径目录:/容器内目录 镜像名
bash 复制代码
[root@localhost ~]# docker run -it --privileged=true -v /tmp/hostData:/tmp/dockerData1 ubuntu /bin/bash
root@0a8bed347ffc:/# 

发现宿主机之前不存在的目录,现在已经自动创建了

bash 复制代码
root@0a8bed347ffc:/# exit
exit
[root@localhost hostData]# cd /tmp/hostData
[root@localhost hostData]# ll
总用量 0

在宿主机对应的目录下创建文件

bash 复制代码
[root@localhost hostData]# touch hello.txt
[root@localhost hostData]# ls
hello.txt

在容器目录中查看

bash 复制代码
root@0a8bed347ffc:/# ls
bin   dev  home  lib32  libx32  mnt  proc  run   srv  tmp  var
boot  etc  lib   lib64  media   opt  root  sbin  sys  usr
root@0a8bed347ffc:/# cd /tmp/dockerData1
root@0a8bed347ffc:/tmp/dockerData1# ls
hello.txt

在容器中再创建一个文件

bash 复制代码
root@0a8bed347ffc:/tmp/dockerData1# touch hi.txt

回到宿主机中查看

bash 复制代码
root@0a8bed347ffc:/# read escape sequence
[root@localhost hostData]# ll
总用量 0
-rw-r--r-- 1 root root 0 12月  9 15:11 hello.txt
-rw-r--r-- 1 root root 0 12月  9 15:22 hi.txt

发现已经同步

把容器停止后再次在宿主机对应的目录里再次创建文件

bash 复制代码
[root@localhost hostData]# docker stop 0a8bed347ffc
0a8bed347ffc
[root@localhost hostData]# touch a.java
[root@localhost hostData]# ll
总用量 0
-rw-r--r-- 1 root root 0 12月  9 15:27 a.java
-rw-r--r-- 1 root root 0 12月  9 15:11 hello.txt
-rw-r--r-- 1 root root 0 12月  9 15:22 hi.txt

再次启动容器进入对应目录查看

bash 复制代码
[root@localhost hostData]# docker exec -it 0a8bed347ffc /bin/bash
root@0a8bed347ffc:/# cd /tmp/dockerData1
root@0a8bed347ffc:/tmp/dockerData1# ls
a.java  hello.txt  hi.txt

即使容器停止了再次启动容器后,文件仍然可以同步

进行查看数据卷的挂载

bash 复制代码
[root@localhost /]# docker inspect 0a8bed347ffc

上面的挂载默认在容器的内部都可以进行读写操作,如果只想在容器内部进行读操作,需要加上:ro标识

bash 复制代码
docker run -it --privileged=true -v /tmp/hostData:/tmp/dockerData1:ro ubuntu /bin/bash

发现创建文件失败

bash 复制代码
root@096812c74cfd:/# cd /tmp/dockerData1
root@096812c74cfd:/tmp/dockerData1# touch b.txt
touch: cannot touch 'b.txt': Read-only file system

如果宿主机写入内容,容器可以读到

容器数据卷的继承

先启动一个ubuntu容器1

bash 复制代码
[root@localhost /]# docker run -it --privileged=true -v /tmp/hostData:/tmp/data --name=u1 ubuntu /bin/bash

再启动容器1继承容器2的卷规则

bash 复制代码
docker run -it --privileged=true --volumes-from 父类 --name u2 ubuntu
bash 复制代码
[root@localhost /]# docker run -it --privileged=true --volumes-from u1 --name=u2 ubuntu /bin/bash

在容器1中创建文件

bash 复制代码
[root@localhost /]# docker exec -it b3f94425fa58 /bin/bash
root@b3f94425fa58:/# cd /tmp/data
root@b3f94425fa58:/tmp/data# touch abc.java
root@b3f94425fa58:/tmp/data# ls
a.java  abc.java  hello.txt  hi.txt

在容器2中查看

bash 复制代码
[root@localhost /]# docker exec -it ddd332ab820c /bin/bash
root@ddd332ab820c:/# cd /tmp/data
root@ddd332ab820c:/tmp/data# ls
a.java  abc.java  hello.txt  hi.txt

发现容器2中也存在了abc.java文件,这样就实现了不同容器之间的数据共享

相关推荐
Lupino7 小时前
别再只聊 AI 写代码了:技术负责人要把“变更治理”提到第一优先级
python·docker·容器
Sheffield4 天前
Docker的跨主机服务与其对应的优缺点
linux·网络协议·docker
Sheffield4 天前
Alpine是什么,为什么是Docker首选?
linux·docker·容器
马艳泽4 天前
win10下运行Start Broker and Proxy报错解决
docker
用户13573999256605 天前
Windows 从 0 搭建 WSL2 原生 AI 开发环境:Codex + Docker + VSCode
docker
vi_h5 天前
在 macOS 上通过 Docker 安装并运行 Ollama(详细可执行教程)
macos·docker·ollama
黑心老魔5 天前
通过 Docker 创建开发环境
docker·开发环境
冬奇Lab6 天前
一天一个开源项目(第41篇):Workout.cool - 现代化开源健身教练平台,训练计划与进度追踪
docker·开源·资讯
天朝八阿哥6 天前
使用Docker+vscode搭建离线的go开发调试环境
后端·docker·visual studio code
阿虎儿7 天前
Docker安装(非sudo用户可用)
docker