容器中管理数据主要有两种方式:
数据卷(Data Volumes)
数据卷容器(Data Volumes Dontainers)
数据卷
使用-v可以挂载一个本地的目录到容器中作为数据卷。
[[email protected] /]$ ls /b2b backup prog_update wasStatus.log [[email protected] /]$ docker run -d --name=tomcat -v /b2b:/test -it centos /bin/bash f85c616bde3317c857b657355561a1cfa4203fab2b8619386435e541089bde23 [[email protected] /]$ docker exec -it tomcat /bin/bash [[email protected] /]# ls /test backup prog_update wasStatus.log[[email protected] /]# touch test/demo[[email protected] /]# ls /testbackup demo prog_update wasStatus.log[[email protected] /]# exitexit[[email protected] /]$ ls /b2bbackup demo prog_update wasStatus.log
可以看见容器中已经挂载了/b2b目录了,并有其中数据。
数据卷容器
如果容器之间需要共享一些持续更新的数据,最简单的方式就是是用户数据卷容器,数据卷容器就是一种普通容器,专门提供数据卷供其它容器挂载使用。
创建数据卷容器dbdata
[[email protected] /]$ docker run -it -v /dbdata:/dbdata --name dbdata centos[[email protected] /]
创建db1和db2两个容器,并使用--volumes-from挂载dbdata容器中的数据卷
[[email protected] /]$ docker run -it --volumes-from dbdata --name db1 centos [[email protected] /]$ docker run -it --volumes-from dbdata --name db2 centos
这样三个容器任何一个容器在该目录下写入,其它容器都能看见。
备份
备份dbdata数据卷容器中的数据到主机的当前目录。
[[email protected] /]$ docker run --volumes-from dbdata -v $(pwd):/backup --name worker centos tar zcf /backup/backup.tar.gz /dbdata tar: Removing leading `/‘ from member names [[email protected] /]$ ls b2b boot dev lib media net root srv tmp backup.tar.gz cgroup etc lib64 misc opt sbin sys usr bin dbdata home lost+found mnt proc selinux test var [[email protected] /]$ tar -tvf backup.tar.gz drwxr-xr-x root/root 0 2016-08-26 10:51 dbdata/ -rw-r--r-- root/root 0 2016-08-26 10:40 dbdata/demo -rw-r--r-- root/root 6 2016-08-26 10:48 dbdata/test.txt -rw-r--r-- root/root 0 2016-08-26 10:51 dbdata/hello
恢复
创建一个带有数据卷的容器
[[email protected] /]$ docker run -v /dbdata/dbdata --name db centos /bin/bash
恢复
[[email protected] /]$ docker run --volumes-from db -v $(pwd):/backup centos tar xf /backup/backup.tar.gz
时间: 2024-11-07 09:34:22