Docker三 | 数据卷
2023-12-13 03:30:57
目录
?Docker数据卷简介
????????Docker容器产生的数据,如果不备份,当容器实例删除后,容器中的数据也会消失,为了保存数据可以在Docker中使用数据卷。Docker数据卷是宿主机的一个可以供一个或多个容器使用的特殊目录,它可以在容器之间共享和重用,使得本地与容器间传递数据更高效。对数据卷的修改会立马生效,在容器内部与本地目录均可对数据卷进行修改。
添加数据卷的命令
docker run -it --privileged=true -v /宿主机绝对路径目录:/容器内目录 镜像名
[root@localhost ~]# docker run -it --privileged=true -v /tmp/hostData:/tmp/dockerData1 ubuntu /bin/bash
root@0a8bed347ffc:/#
发现宿主机之前不存在的目录,现在已经自动创建了?
root@0a8bed347ffc:/# exit
exit
[root@localhost hostData]# cd /tmp/hostData
[root@localhost hostData]# ll
总用量 0
在宿主机对应的目录下创建文件
[root@localhost hostData]# touch hello.txt
[root@localhost hostData]# ls
hello.txt
?在容器目录中查看
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
在容器中再创建一个文件
root@0a8bed347ffc:/tmp/dockerData1# touch hi.txt
回到宿主机中查看
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
发现已经同步
把容器停止后再次在宿主机对应的目录里再次创建文件
[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
再次启动容器进入对应目录查看
[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
即使容器停止了再次启动容器后,文件仍然可以同步
进行查看数据卷的挂载
[root@localhost /]# docker inspect 0a8bed347ffc
上面的挂载默认在容器的内部都可以进行读写操作,如果只想在容器内部进行读操作,需要加上:ro标识
docker run -it --privileged=true -v /tmp/hostData:/tmp/dockerData1:ro ubuntu /bin/bash
发现创建文件失败?
root@096812c74cfd:/# cd /tmp/dockerData1
root@096812c74cfd:/tmp/dockerData1# touch b.txt
touch: cannot touch 'b.txt': Read-only file system
如果宿主机写入内容,容器可以读到
容器数据卷的继承
先启动一个ubuntu容器1
[root@localhost /]# docker run -it --privileged=true -v /tmp/hostData:/tmp/data --name=u1 ubuntu /bin/bash
?再启动容器1继承容器2的卷规则
docker run -it --privileged=true --volumes-from 父类 --name u2 ubuntu
[root@localhost /]# docker run -it --privileged=true --volumes-from u1 --name=u2 ubuntu /bin/bash
在容器1中创建文件?
[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中查看
[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文件,这样就实现了不同容器之间的数据共享
文章来源:https://blog.csdn.net/m0_72832574/article/details/134895276
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!