六、【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 的练手项目,使用了很多当时 ...
随机推荐
- 2020最新ArchLinux安装(KDE桌面)
许多网友反映之前的教程安装好后连不上互联网,最近我刚好又安装了一遍,总结出以下没毛病的过程 按照此教程需要你会基本的vim操作(或其他文本编辑工具比如nano),基本的fdisk分盘操作(或其他分盘工 ...
- iTerm2 都不会用,还敢自称老司机?(上)
对于需要长期与终端打交道的工程师来说,拥有一款称手的终端管理器是很有必要的,对于 Windows 用户来说,最好的选择是 Xshell,这个大家都没有异议.但对于 MacOS 用户来说,仍然毋庸置疑, ...
- npm项目创建初始过程详解
npm install 就是安装模块,npm run dev 就是执行npm script中的命令.当我们执行npm命令的时候,它到哪里去找,这就要说到每个node项目中都有的核心文件package ...
- 前端解决跨域问题的终极武器——Nginx反向代理
提到代理,分为:正向代理和反向代理. 正向代理:就是你访问不了Google,但是国外有个VPN可以访问Google,你访问VPN后叫它访问Google,然后把数据传给你. 正向代理隐藏了真实的客户端. ...
- java 发送邮件详细讲解
一.JavaMail概述: JavaMail是由Sun定义的一套收发电子邮件的API,不同的厂商可以提供自己的实现类.但它并没有包含在JDK中,而是作为JavaEE的一部分. 厂商所提供 ...
- JavaScript入门进阶(二)
JavaScript进阶入门(二) 转换为数字 使用parseInt() parseInt函数会先查看位置0处的字符,如果该位置不是有效数字,则将返回NaN,如果0处的字符是数字,则将查看位置1处的字 ...
- Serverless与微服务
Serverless 是一个更大的范畴,Serverless 不只计算,也包括存储.数据库.中间件等各种服务.Serverless = FaaS(函数即服务) + BaaS(后端即服务).其中 Ser ...
- tkinter学习1
GUI 用户交互界面 tkinter 介绍 tkinter是 python自带的gui库,对图像处理库tk的封装 #导入tkinter库 import tkinter #创建主窗口对象 root = ...
- 建议11:增强数组排序的sort功能
sort方法不仅按字母顺序进行排序,还可以根据其他顺序执行操作.这时就必须为方法提供一个比较函数的参数,该函数要比较两个值,然后返回一个用于说明这两个值得相对顺序的数字.比较函数应该具有两个参数a和b ...
- Journal of Proteomics Research | Th-MYCN转基因小鼠的定量蛋白质学分析揭示了Aurora Kinase抑制剂改变代谢途径和增强ACADM以抑制神经母细胞瘤的进展
题目:Quantitative Proteomics of Th-MYCN Transgenic Mice Reveals Aurora Kinase Inhibitor Altered Metabo ...