在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
有些容器会自动产生一些数据,为了不让数据随着container的消失而消失,保证数据的安全性。例如:数据库容器,数据表的表会产生一些数据,如果我把container给删除,数据就丢失。为了保证数据不丢失,这就有了Volume的存在。 Data Volume 结构图 Docker持久化数据的方案
Volume的类型 受管理的data Volume,由docker后台自动创建。 绑定挂载的Volume,具体挂载位置可以由用户指定。 数据持久化之Data Volume 以官方镜像mysql的dockerfile文件为例 。其中dockerfile通过volume指定了当前容器中要备份的文件路径,但是并没有指定说要保存到宿主机的哪个位置。 volume:映射容器中的文件到本地宿主机硬盘中 在我们使用 启动mysql镜像容器的时候,容器会默认在宿主机生成一个volume,至于位置在哪,名字是什么,可以通过如下命令查看 #查看所有volume docker volume ls #删除指定volume docker volume rm [volume name] #查看volume详细 docker volume inspect [volume name] 此时我们删除容器,发现volume数据卷还在,有保留。 此时我们会觉得这个data volume name 的名字很长,很不好理解。我们可以通过 :前参数是volume name, :后面的是要备份的文件目录(容器) 此时我们删除容器,volume数据卷还在,我们用这个名为mysql的volume作为一个新容器的数据卷,覆盖它。
进入mysql2容器中,mysql -uroot 进入数据库中,发现当前数据库数据和之前删除的容器中的数据库数据一样。 数据持久化之bind Mounting 和上面Data Volume不同的是,bind Mounting只能通过 运行容器的时候指定本地的一个文件目录和容器中的一个文件目录的映射,通过这个可以做文件数据同步,2方无论哪一方有修改,另一方都会同步内容 docker run -d -v $(pwd):/usr/share/nginx/html -p 80:80 --name nginx nginx 这个时候 值得注意的是 ,使用bind Mounting方式做数据卷的映射时,首次 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持极客世界。 |
请发表评论