本章讨论:volume的备份,恢复,迁移和销毁

1.备份

通过前面的大量的实验,我们知道volume 是依赖host存在的,是host中的文件或目录,所以volume 的备份实际是对文件系统的备份。

我们之前学习的搭建本地私有仓库registry:所有的上传到本地私有仓库里面的镜像都是存在在host目录中,所以我们只需要定时备份这个目录就可以了

进行备份:

2.恢复

如果数据损坏,直接将之前备份的数据拷贝到/test1中

将test1中的数据删除,我们之前是上传的192.168.7.222/vim这个镜像,下面pull这个镜像

由于我删除了test1中的数据,所以pull失败;我们再将test1的备份数据拷贝回来,看是否能成功pull镜像

依然是not found???原因是什么??

volume的恢复按正常来说只要将之前备份的数据拷贝过来,就可以了,但是本实验应该是有问题的,这个之后再来详细的探讨!!

3.迁移

如果我们想使用新版本的registry,这就涉及到数据迁移,方法是:

1.docker  stop当前的registry容器

2.启动一个新版本的容器并mount原有的volume:docker run -d -p 5000:5000 -v /test1:/var/lib/registry registry

标红的路径一定要和源容器中的路径一致,否则迁移不成功

4.销毁

可以删除不再需要的volme,但是一定要清楚自己在干什么,因为volume删除后,数据是找不回来的。

docker 不会销毁bind mount,删除数据的工作职能由host完成;

对于docker managed volume,在删除容器docker rm的时候可以带上-v参数,docker会将容器用到的volume一并删除,但前提是没有其他容器mount 到该volume,目的是保护数据。

如果删除容器的时候没有带-v,这样就会产生孤儿volume,docker提供了volume自命令可以对docker managed volume进行维护:

实验中当我们删除容器的时候没有加-v的参数,但是volume还存在,这种就是孤儿volume,对于这种volume可以使用docker rm volume进行删除

但是通过docker volume ls只能看到volume不能对应具体的容器,我们无法判读哪个是孤儿容器,该如何去管理呢?

可以通过docker volume prune删除孤儿volume

批量删除孤儿volume:docker volume rm $(docker volume ls -q)

centos7下安装docker(13.3volume生命周期管理)的更多相关文章

  1. CentOS7下安装docker(Docker系列1)

    CentOS7下安装docker 系统要求 为了安装docker,需要准备 64-bit的CentOS 7 删除非官方的Docker包 yum的仓库中有一个很旧的Docker包, 现在Docker官方 ...

  2. docker(一) Centos7下安装docker

    docker(一) Centos7下安装dockerdocker(二) windows10下安装dockerdocker(三) 镜像和容器常用命令 docker(四) 使用Dockerfile构建镜像 ...

  3. centos7下安装docker与镜像加速

    1.背景 centos7下安装docker 2.安装 第一步:检查是否为centos7版本 第二步:依赖环境安装 执行如下两个命令: yum -y install gcc yum -y install ...

  4. centos7 下安装docker报错:You could try using...

    搞了台VPS,想要装docker,发现死活装不上,各种报错.之前系统是centos6,发现官方现在已经不支持centos6了,遂升级到centos7,然后还是出现下面这个错误. Error: Pack ...

  5. centos7下安装docker(13.4容器volume总结)

    最近我们学习了docker 存储,首先docker存储有两种:storage driver和data volume. storage driver是由镜像层和容器层组成的,可以通过docker ins ...

  6. Linux(centos7)下安装Docker

    近期公司开始推Docker技术.这个系列的文章都是基于CentOS7系统下进行讲解的. Docker简介 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器 ...

  7. centos7下安装docker(14安装docker machine)

    之前我们做的实验都是在一个host上面的,其实在真正的环境中有多个host,容器在这些host上面启动,运行,停止和销毁,相关容器会通过网络相互通信,无论他们是否运行在相同的host上面. 对于这种歌 ...

  8. centos7下安装docker(24docker swarm 数据管理)

    service的容器副本会scal up/down,会failover,会在不同的主机上创建和销毁,这就引出一个问题,如果service有数据,那么这些数据该如何存放呢? 1.打包在容器中: 显然不行 ...

  9. centos7下安装docker(21docker swarm集群创建)

    创建swarm集群: 实验环境:盗图 swarm-manager是manager node,swarm-worker1和swarm-worker2是worker node. 所有节点的docker版本 ...

随机推荐

  1. Hive基础之Hive与关系型数据库的比较

    Hive与关系型数据库的比较     使用Hive的CTL(命令行接口)时,你会感觉它很像是在操作关系型数据库,但是实际上,Hive和关系型数据库有很大的不同.       1)Hive和关系型数据库 ...

  2. js------科学计数法转换为正常小数

    // toD.js文件export default (val) => { const e = String(val) let rex = /^([0-9])\.?([0-9]*)e-([0-9] ...

  3. centos每天自动备份mysql数据库

    #!/bin/bash PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin export PATH #数据库用户名 db ...

  4. 【手记】解决“未能创建 SSL/TLS 安全通道”异常

    之前写了一个桌面程序,程序会间歇性访问某个https接口,一直用的好好的,今天突然报错了,异常就发生在访问接口的地方,曰“请求被中止,未能创建 SSL/TLS 安全通道.”,另外有台电脑也有跑该程序, ...

  5. EF 中多个数据库迁移

    Entity Framework 允许用户基于实体来创建和更新数据库,当项目中只有一个DBContext 时使用默认的参数就可以实现数据库的一些操作.当有多个DbContext 时需要制定参数才能完成 ...

  6. HDFS的副本存放策略(全)

    HDFS的副本存放策略   HDFS作为Hadoop中的一个分布式文件系统,而且是专门为它的MapReduce设计,所以HDFS除了必须满足自己作为分布式文件系统的高可靠性外,还必须为MapReduc ...

  7. Hive原理总结(完整版)

    目录 课程大纲(HIVE增强) 3 1. Hive基本概念 4 1.1 Hive简介 4 1.1.1 什么是Hive 4 1.1.2 为什么使用Hive 4 1.1.3 Hive的特点 4 1.2 H ...

  8. cordova启动页面和图标的设置

    一.config.xml配置 在cordova5.0版本以后,需要安装cordova-plugin-splashscreen插件以后才能修改和设置App的启动页面. 安装splashscreen插件: ...

  9. html常用标签整理

    html文档结构 <!DOCTYPE html> <html lang="zh-CN"> #这个lang表示语言,zh-CN中文的意思,整个文档的内容以中文 ...

  10. 使用node.js进行API自动化回归测试

    概述 传统的QA自动化测试通常是基于GUI的,比如使用Selenium,模拟用户在界面上操作.但GUI测试的开发.维护成本和运行的稳定性一直是测试界的老大难问题.投入大量的人力物力开发.维护.运行,却 ...