Docker的持久化存储和数据共享(四)

著做权归做者全部,任何形式的转载都请联系做者得到受权并注明出处。

有些容器会自动产生一些数据,为了避免让数据随着container的消失而消失,保证数据的安全性。例如:数据库容器,数据表的表会产生一些数据,若是我把container给删除,数据就丢失。为了保证数据不丢失,这就有了Volume的存在。html

Data Volume 结构图 mysql

Docker持久化数据的方案

  • 基于本地文件系统的Volume。能够再执行Docker create或Docker run时,经过-v参数将主机的目录做为容器的数据卷。这部分功能即是基本的本地文件系统的volume管理。
  • 基于plugin的Volume,支持第三方的存储方案,好比NAS,aws

Volume的类型nginx

  • 受管理的data Volume,由docker后台自动建立。
  • 绑定挂载的Volume,具体挂载位置能够由用户指定。

数据持久化之Data Volume

以官方镜像mysql的dockerfile文件为例。其中dockerfile经过volume指定了当前容器中要备份的文件路径,可是并无指定说要保存到宿主机的哪一个位置。git

volume: 映射容器中的文件到本地宿主机硬盘中github

在咱们使用 docker run 启动mysql镜像容器的时候,容器会默认在宿主机生成一个volume,至于位置在哪,名字是什么,能够经过以下命令查看

#查看全部volume
docker volume ls
#删除指定volume
docker 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文件的方式。sql

运行容器的时候指定本地的一个文件目录和容器中的一个文件目录的映射,经过这个能够作文件数据同步,2方不管哪一方有修改,另外一方都会同步内容docker

docker run -d -v $(pwd):/usr/share/nginx/html -p 80:80 --name nginx nginx
复制代码

这个时候-v:前面的参数是本机文件路径, :后面是docker文件目录(容器)数据库

值得注意的是,使用bind Mounting方式作数据卷的映射时,首次docker run -v 运行,若是本机的文件夹是没有内容的,docker容器中的文件夹是有内容的,则本机的会覆盖dokcer容器中的,也就是容器中本来有内容的也会没有内容。安全

相关文章
相关标签/搜索