时间:2021-05-19
有些容器会自动产生一些数据,为了不让数据随着container的消失而消失,保证数据的安全性。例如:数据库容器,数据表的表会产生一些数据,如果我把container给删除,数据就丢失。为了保证数据不丢失,这就有了Volume的存在。
Data Volume 结构图
Docker持久化数据的方案
Volume的类型
受管理的data Volume,由docker后台自动创建。
绑定挂载的Volume,具体挂载位置可以由用户指定。
数据持久化之Data Volume
以官方镜像mysql的dockerfile文件为例 。其中dockerfile通过volume指定了当前容器中要备份的文件路径,但是并没有指定说要保存到宿主机的哪个位置。
volume:映射容器中的文件到本地宿主机硬盘中
在我们使用 docker run
启动mysql镜像容器的时候,容器会默认在宿主机生成一个volume,至于位置在哪,名字是什么,可以通过如下命令查看
#查看所有volumedocker volume ls#删除指定volumedocker volume rm [volume name]#查看volume详细docker volume inspect [volume name]此时我们删除容器,发现volume数据卷还在,有保留。
此时我们会觉得这个data volume name 的名字很长,很不好理解。我们可以通过 -v 如下命令来指定生成的volume name docker run -d -v mysql:/var/lib/mysql --name mysql mysql5.7
-v
:前参数是volume name, :后面的是要备份的文件目录(容器)
此时我们删除容器,volume数据卷还在,我们用这个名为mysql的volume作为一个新容器的数据卷,覆盖它。
docker run -d -v mysql:/var/lib/mysql --name mysql2 mysql5.7
进入mysql2容器中,mysql -uroot 进入数据库中,发现当前数据库数据和之前删除的容器中的数据库数据一样。
数据持久化之bind Mounting
和上面Data Volume不同的是,bind Mounting只能通过 docker run -v 方式启动,无法使用dockerfile文件的方式。
运行容器的时候指定本地的一个文件目录和容器中的一个文件目录的映射,通过这个可以做文件数据同步,2方无论哪一方有修改,另一方都会同步内容
docker run -d -v $(pwd):/usr/share/nginx/html -p 80:80 --name nginx nginx这个时候 -v :前面的参数是本机文件路径, :后面是docker文件目录(容器)
值得注意的是 ,使用bind Mounting方式做数据卷的映射时,首次 docker run -v 运行,如果本机的文件夹是没有内容的,docker容器中的文件夹是有内容的,则本机的会覆盖dokcer容器中的,也就是容器中原本有内容的也会没有内容。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Android数据共享sharedPreferences的使用方法Android中通过sharedPreferences来持久化存储数据并进行共享在Activi
阅读本文前,希望你已经对volumes和bindmounts有了初步的了解,具体可以参考以下文章:docker数据持久化之volumesdocker数据持久化之
本文简述如何使用docker部署mysql,同时持久化数据.我们会用到tutum-docker-mysql这个项目来搭建一个mysql,省去重头写dockerf
RDB是Redis内存到硬盘的快照,用于redis持久化,创建RDB二进制文件,将存储在内存中的数据,持久化的放到硬盘中,当我们需要这些数据的时候,启动载入RD
阅读本文前,希望你已经对volumes有了初步的了解,具体可以参考这篇文章:docker数据存储之volumes详解默认容器的数据的读写发生在容器的存储层,当容