六、【Docker笔记】Docker数据管理
前几节我们介绍了Docker的基本使用和三大核心概念,那么我们在使用Docker的过程中,Docker中必然产生了大量的数据,对于这些数据我们需要查看或者对这些数据进行一个备份,也有可能容器之间的数据需要进行共享,这些都涉及到了容器的数据管理操作。
关于容器中管理数据Docker主要有两种方式:数据卷(Data Volumes)和数据卷管理(Data Volumes Dontainers)。
一、数据卷
数据卷是一个可供容器使用的特殊目录,它绕过了文件系统,可提供多种特性:
- 数据卷可以在容器之间共享和重用
- 对数据卷的修改会立马生效
- 对数据卷的更新不会影响镜像
- 卷会一直存在,直到没有容器使用为止
1、在容器中创建数据卷
在使用 docker run 命令运行镜像为容器时,可使用 -v 标记即在容器内创建一个数据卷,多次 -v 即可创建多个数据卷。
# 创建一个 webapp 容器,并将一个数据卷挂载到 /webapp 目录下
$ sudo docker run -d -P --name web -v /webapp training/webapp python app.py
$ sudo docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
d3426095a52b training/webapp "python app.py" 8 seconds ago Up 7 seconds 0.0.0.0:32768->5000/tcp web
# 用浏览器访问 http://192.168.0.128:32768 (192.168.0.128为主机IP) 可看到浏览器打印一行 hello world!
2、挂载主机目录为数据卷
同样使用 -v 标记,也可以指定挂载一个本地已有的目录到容器中作为数据卷。推荐方式
# 挂载一个本地主机目录为容器的数据卷
$ sudo docker run -d -P --name web -v /opt/webapp(主机目录):/opt/webapp(容器目录) training/webapp python app.py
这种挂载方式对功能的开发和测试非常方便,我们可以将自己的程序或数据放到一个主机目录中,之后创建为数据卷,哪怕主机目录不存在也没关系,Docker会自动帮助我们创建。当我们挂载之后,此时的数据卷权限为读写,我们可以通过 ro 将其指定为只读。
$ sudo docker run -d -P --name web -v /opt/webapp:/opt/webapp:ro training/webapp python app.py
3、挂载本地主机文件为数据卷
-v 标记也可挂载一个本地主机文件作为数据卷。不推荐使用
$ sudo docker run --rm -it -v ~/.bash_history:/.bash_history ubuntu /bin/bash
二、数据卷容器
当我们需要在多个容器之间共享一些持续更新的数据,最简单的方式就是使用数据卷容器,数据卷容器也是一个普通的Docker容器,只是这个容器它专门用来提供数据卷以供其他容器挂载。
# 0. 创建一个数据卷容器 dbdata,并创建一个数据卷挂载到 /dbdata
$ sudo docker run -itd -v /dbdata --name dbdata ubuntu
# 1. 查看容器的 /dbdata 目录
root@xxx:/# ls
bin boot dbdata dev etc home lib lib64 media mnt opt proc root run sbin srv sys tmp usr var
# 2. 在其他容器中挂载 dbdata 容器中的数据卷
$ sudo docker run -itd --volumes-from dbdata --name db1 ubuntu
$ sudo docker run -itd --volumes-from dbdata --name db2 ubuntu
# 说明:即挂载成功,之后不管哪个容器修改了数据卷,其他容器都可即时查看。
# 3. 在 dbdata 容器中创建 test.txt 文件
$ sudo docker exec -ti fdcd9728f78e /bin/bash
root@fdcd9728f78e:/# cd /dbdata/
root@fdcd9728f78e:/dbdata# ll
total 4
drwxr-xr-x. 2 root root 6 Apr 9 12:38 ./
drwxr-xr-x. 22 root root 4096 Apr 9 12:38 ../
root@fdcd9728f78e:/dbdata# touch test.txt
root@fdcd9728f78e:/dbdata# ls
test.txt
# 4. 在 db1 和 db2 容器中进行查看
$ sudo docker exec -ti 0365f0f09a87 /bin/bash
root@0365f0f09a87:/# cd /dbdata/
root@0365f0f09a87:/dbdata# ls
test.txt
root@0365f0f09a87:/dbdata#
# 5. 当前运行的三个容器ID
$ sudo docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
b57b6954e924 ubuntu "/bin/bash" 2 minutes ago Up 2 minutes db2
0365f0f09a87 ubuntu "/bin/bash" 2 minutes ago Up 2 minutes db1
fdcd9728f78e ubuntu "/bin/bash" 7 minutes ago Up 7 minutes dbdata
在以上操作完成后,若我们此时删除容器,数据卷并不会被删除。若要删除数据卷,必须删除最后一个还挂载它的容器时显示的使用 docker rm -v 命令来指定同时删除关联的容器。
三、利用数据卷容器迁移数据
1、备份
使用以下命令来备份 dbdata 数据卷容器内的数据卷:
$ sudo docker run --volumes-from dbdata -v $(pwd):/backup --name worker ubuntu tar cvf /backup/backup.tar /dbdata
2、恢复
那么对备份的数据如何恢复,需要做两步走:
# 0. 创建一个带有数据卷的容器 dbdata2
$ sudo docker run -itd -v /dbdata --name dbdata2 ubuntu /bin/bash
# 1. 创建另一个新的容器,挂载 dbdata2 的容器,并使用 untar 解压备份文件到所挂载的容器卷中
$ sudo docker run --volumes-from dbdata2 -v $(pwd):/backup busybox tar xvf /backup/backup.tar
六、【Docker笔记】Docker数据管理的更多相关文章
- docker笔记--docker 各系统安装
在线安装 Docker 在 CentOS/RHEL 中安装 Docker 在终端中运行下面的命令安装 Docker. sudo yum install -y yum-utils sudo yum-co ...
- Docker笔记——Docker安装及制作镜像
1 Docker安装本文中Docker运行环境为Ubuntu 14.04.1 LTS 3.13.0-32-generic x64参考:https://docs.docker.com/v1.11/eng ...
- Docker笔记(八):数据管理
前面(哪个前面我也忘了)有说过,如果我们需要对数据进行持久化保存,不应使其存储在容器中,因为容器中的数据会随着容器的删除而丢失,而因通过将数据存储于宿主机文件系统的形式来持久化.在Docker容器中管 ...
- Docker笔记(六):容器管理
原文地址:http://blog.jboost.cn/2019/07/21/docker-6.html 容器是Docker中的另一核心概念,在Docker中,应用的运行都是在容器内进行的,容器则基于镜 ...
- Docker笔记(九):网络管理
Docker的应用运行在容器中,其相互之间或与外部之间是如何通信的,涉及到哪些知识点,本文对相关内容进行整理.因网络这块牵涉的面较多,因此只从日常使用或理解的角度出发,过于专业的就不深入探讨了. 1. ...
- Docker笔记(十一):Dockerfile详解与最佳实践
Dockerfile是一个文本文件,包含了一条条指令,每条指令对应构建一层镜像,Docker基于它来构建一个完整镜像.本文介绍Dockerfile的常用指令及相应的最佳实践建议. 1. 理解构建上下文 ...
- Docker笔记一:基于Docker容器构建并运行 nginx + php + mysql ( mariadb ) 服务环境
首先为什么要自己编写Dockerfile来构建 nginx.php.mariadb这三个镜像呢?一是希望更深入了解Dockerfile的使用,也就能初步了解docker镜像是如何被构建的:二是希望将来 ...
- Docker容器的数据管理
Docker容器的数据管理 Docker容器的数据管理 什么是数据卷(Data Volume)? 数据卷是经过特殊设计的目录,可以绕过联合文件系统(UFS),为一个或者多个容器提供访问 数据卷设计的目 ...
- Docker笔记一:Docker介绍
目录 什么是Docker? Docker的核心概念 Docker镜像命令 Docker容器命令 Docker实战 查看我的镜像 启动Redis Docker中国镜像加速 血与泪的教训 什么是Docke ...
- Spring Boot 2 (六):使用 Docker 部署 Spring Boot 开源软件云收藏
Spring Boot 2 (六):使用 Docker 部署 Spring Boot 开源软件云收藏 云收藏项目已经开源3年多了,作为当初刚开始学习 Spring Boot 的练手项目,使用了很多当时 ...
随机推荐
- 『配置』服务器搭建 Office Online Server2016 实现文档预览
博主有话说:这个过程我遇到了很多错误,所以出了一个错误整理文章,所以当你在配置过程中遇到了问题,可以先去这篇文章里找找!加油! 先打开我吧:https://www.cnblogs.com/pukua/ ...
- Promise,Generator,Await/Async
上节中忘记讲:Iterator接口和Generator函数的关系了,Symbol.iterator方法的最简单的实现就是通过Generator函数: let myIterable = { [Symbo ...
- Html5 部分帮助文档 未完待续
W3cSchoolH5帮助文档 Video属性 视频播放效果 Video标签 src视频得目录 controls属性提供添加 播放 和音量控件 当然呢 不设置宽和高得话 视频会很大 Video还可以 ...
- git的日常使用(补课)
使用git的一些反响 如果在github上做一个仓库来使用的话... 首先手动在github上创建一个空的仓库,默认没有任何东西的 使用git的命令 git pull 创建的github仓库地址 能把 ...
- C语言程序设计(十一) 指针和数组
第十一章 指针和数组 一旦给出数组的定义,编译系统就会为其在内存中分配固定的存储单元,相应的,数组的首地址也就确定了 C语言中的数组名有特殊的含义,它代表存放数组元素的连续存储空间的首地址 //L11 ...
- spring boot 学习笔记(一)
学习链接:http://www.cnblogs.com/ityouknow/category/914493.html 定义 spring boot 是由pivotal 团队提供的权限框架,设计目的是用 ...
- 实操教程丨使用Pod安全策略强化K8S安全
本文来自Rancher Labs 什么是Pod安全策略? Kubernetes Pod安全策略(PSP)是Kubernetes安全版块中极为重要的组件.Pod安全策略是集群级别的资源,用于控制Pod安 ...
- (转)C++中的delete
转载自:http://blog.csdn.net/sparkliang/article/details/3670930 为了防止内存泄漏,每一个动态内存分配必须有一个等同相反的内存释放操作,delet ...
- vscode 新版设置备份20200221 settings.json
vscode 新版设置备份20200221 { "sync.gist": "9e6a5f7e8c52047b03c8732ff88aab0e", "s ...
- 问不倒的HTTP协议
一.HTTP简介 1.HTTP HTTP:超文本传输协议,是一种通信协议:允许超文本标记文档从Web服务器传送到客户端的浏览器中. 简单:传输html文件的协议. Web:是一种基于超文本和HTML的 ...