docker存储卷

文章目录

    • 容器数据管理
    • 在容器中使用数据卷
      • 在容器内创建一个数据卷
      • 挂载一个主机目录作为数据卷
      • 挂载一个本地主机文件作为数据卷
    • 数据卷容器

容器数据管理

用户在使用Docker的过程中,往往需要能查看容器内应用产生的数据,或者需要把容器内的数据进行备份,甚至多个容器之间进行数据的共享,这必然涉及容器的数据管理操作。

容器中管理数据主要有两种方式:

  • 数据卷(Data Volumes)
  • 数据卷容器(Data Volumes Containers)

在容器中使用数据卷

在容器内创建一个数据卷

下面使用nginx镜像创建一个web容器,并创建一个数据卷挂载到容器的/webapp目录下:

[root@salt1 ~]#  docker run -d -P --name web -v /webapp nginx
c091d272b653107060a4c1db9ef0ea0f90c1a2c4d15cf8b3d8fd6ed373551f0a

挂载一个主机目录作为数据卷

加载主机的/var/www/html目录到容器的/webapp目录:
这个功能在进行测试的时候非常方便,比如用户可以放置一些程序或数据到本地目录中,然后在容器内运行和使用。另外,本地目录的路径必须是绝对路径,如果目录不存在,Do
cker会自动创建。

[root@salt1 ~]# docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED              STATUS              PORTS                   NAMES
c091d272b653        nginx               "nginx -g 'daemon of…"   About a minute ago   Up About a minute   0.0.0.0:32778->80/tcp   web
[root@salt1 ~]# docker exec -it c091d272b653 /bin/bash
root@c091d272b653:/# ls /webapp/
root@c091d272b653:/# touch /webapp/hello
root@c091d272b653:/# ls /webapp/
hello
[root@salt1 ~]# ls /var/www/html/
hello

Docker挂载数据卷的默认权限是读写(rw),用户也可以通过(ro)指定为只读:

[root@salt1 ~]# docker run -d -P --name web2 -v /var/www/html:/webapp:ro nginx
10c632d0737c250f791a91cd08be53d3789329186dd2e847d935e5f4d274de6e

挂载一个本地主机文件作为数据卷

-v选项也可以从主机挂载单个文件到容器中作为数据卷:

[root@salt1 ~]# docker run -it --rm -v ~/.bash_history:/.bash_history centos /bin/bash

这样就可以记录在容器输入过的命令历史了。

如果直接挂载一个文件到容器,使用文件编辑工具,包括vi或者sed去修改文件内容的时候,可能会造成inode的改变,这样将会导致错误。所以推荐的方式是直接挂载文件所在的目录。

数据卷容器

如果用户需要在容器之间共享一些持续更新的数据,最简单的方式是使用数据卷容器。数据卷容器其实就是一个普通的容器,专门用它提供数据卷供其他容器挂载使用,方法如下:

首先,创建一个数据卷容器dbdata,并在其中创建一个数据卷挂载到/dbdata:

[root@salt1 ~]# docker run -it -d --name dbdata -v /dbdata centos
9b99ad9c7918153af66174d70f215e101fe6d1b0aea166bd013c5d76b8866c69

然后可以在其他容器中使用–volumes-from来挂载dbdata容器中的数据卷,例如创建db1和db2两个容器,并从dbdata容器挂载数据卷:

[root@salt1 ~]# docker run -d -it --name db1 --volumes-from dbdata centos
3d618cc22ef3a2ad985770b54a7d977c188e105983a95f3799f76acf40ea252a
[root@salt1 ~]# docker run -d -it --name db2 --volumes-from dbdata centos
cda11cf7f5325d9db3c4cfa5e2202e369ba6293f6443664c56a744553f162aff

此时,容器db1和db2都挂载同一个数据卷到相同的/dbdata目录。三个容器任何一方在该目录下的写入,其他容器都可以看到。
例如,在db1容器中创建一个test文件:

[root@salt1 ~]# docker exec -it db1 /bin/bash
[root@3d618cc22ef3 /]# ls
bin	etc   lib64	  mnt	root  srv  usr
dbdata	home  lost+found  opt	run   sys  var
dev	lib   media	  proc	sbin  tmp
[root@3d618cc22ef3 /]# cd dbdata/
[root@3d618cc22ef3 dbdata]# touch test
[root@3d618cc22ef3 dbdata]# ls
test

在db2容器中查看

[root@salt1 ~]# docker exec -it db2 /bin/bash
[root@cda11cf7f532 /]# ls /dbdata/
test

你可能感兴趣的:(Linux课程)