博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
docker之数据卷管理
阅读量:6889 次
发布时间:2019-06-27

本文共 2289 字,大约阅读时间需要 7 分钟。

转自:https://www.cnblogs.com/jsonhc/p/7777811.html

docker之数据卷的备份和还原

1、现在利用镜像创建一个nginx的服务容器,并挂载一个数据卷

[root@docker ~]# docker run -v /data -d -p80:80 --name web1 centos_nginx:v4 55a45a822c29a1e673d7ca2fb65a4d08fe6c896f5b4fa08fac4d45950e9e7f67

2、进入到容器内,向空的数据卷目录/data添加一些数据

[root@docker ~]# docker exec -it web1 /bin/bash[root@55a45a822c29 nginx-1.12.2]# cd /data/[root@55a45a822c29 data]# lltotal 0[root@55a45a822c29 data]# mkdir wadeson[root@55a45a822c29 data]# vim wadeson/web1.textbash: vim: command not found[root@55a45a822c29 data]# vi wadeson/web1.text [root@55a45a822c29 data]# cat wadeson/web1.text this is in web1

3、创建另外一个容器以上面web1容器作为共享数据卷,并将共享的数据卷进行tar压缩备份,并通过映射到本机host

[root@docker ~]# docker run -d --volumes-from web1 -v /root/backup:/backup centos tar cvf /backup/data.tar /data081dd7df6371b86e33106664390a8a2780a1f8fc46d69b88adec2970f6d394cf

上面命令详解:

--volumes-from web1:表示创建的容器基于web1容器内的数据卷(即两个容器共享数据卷),web1的数据卷为/data

tar vcf /backup/data.tar  /data:创建的容器将/data进行tar压缩

-v /root/backup:/backup :将容器内的目录/backup与本机host的/root/backup进行映射

总的命令解释:创建一个新容器数据卷基于共享web1容器的数据卷,将数据卷进行tar压缩到容器内某个目录,并映射到本机host的目录

[root@docker ~]# ll backup/data.tar -rw-r--r--. 1 root root 10240 Nov  2 22:24 backup/data.tar[root@docker ~]# cd backup/[root@docker backup]# lltotal 12-rw-r--r--. 1 root root 10240 Nov  2 22:24 data.tar[root@docker backup]# tar xf data.tar [root@docker backup]# cd data[root@docker data]# lltotal 0drwxr-xr-x. 2 root root 23 Nov  2 22:13 wadeson[root@docker data]# cat wadeson/web1.text this is in web1

而此次创建的容器的状态为exited也不会影响数据卷的备份:

于是基于数据卷的备份就ok了

 

现在将备份好的数据进行恢复还原:

1、创建一个空数据卷的容器web2:(创建的数据卷目录名称必须和备份的数据卷名称一致)

[root@docker ~]# docker run -it -v /data --name web2 centos /bin/bash

[root@090eb911d368 /]# ll /data0/
total 0

2、创建一个容器与web2共享数据卷,将备份的数据解压到数据卷/data中:

[root@docker ~]# docker run --volumes-from web2 -v /root/backup:/backup centos tar xvf /backup/data.tardata/data/wadeson/data/wadeson/web1.text

启动的新容器与web2容器共享数据卷目录/data,而本机host将/root/backup下面的数据压缩文件映射到了新容器的/backup目录下,并执行了命令将数据压缩文件解压到了数据卷/data中

如果没有--volumes-from web2那么将不会有数据卷目录/data

3、创建一个新容器共享数据卷,查看数据内容:

[root@docker ~]# docker run -it --volumes-from web2 --name web3 centos sh -c "ls -l /data/wadeson" total 4-rw-r--r--. 1 root root 16 Nov  3 02:13 web1.text

 

转载于:https://www.cnblogs.com/maohuidong/p/9914780.html

你可能感兴趣的文章
磁盘和文件系统管理(二)
查看>>
WCF中有关Session的小实验
查看>>
C#设计模式(13)——代理模式(Proxy Pattern)
查看>>
如何在VIEW 5中配置日志数据库
查看>>
android的互联网开发 下
查看>>
JDBC连接属性
查看>>
百度地图 demo 在html中显示 在jsp中不显示
查看>>
Mac下安装Caffe
查看>>
RDS-MSSQL问题排查方法
查看>>
实现u-boot对yaffs/yaffs2文件系统下载的支持
查看>>
Android Service与Activity之间通信的几种方式
查看>>
表格模板
查看>>
git reset
查看>>
我的友情链接
查看>>
linux内核和发行版本介绍
查看>>
Linux下网络启动服务器安装和配置方法(pxe+tftp+dhcpd)
查看>>
salt 安装脚本
查看>>
获取Spring容器中的Bean
查看>>
ORA-01210: data file header is media corrupt
查看>>
Aerospike开发指南【中文】
查看>>