概述

大家都知道,docker容器中管理数据主要有两种方式,数据卷和数据卷容器,今天主要详细介绍Docker中的数据管理,也做个备忘!


数据卷

数据卷是一个可供容器使用的特殊目录,它绕过文件系统,可以提供很多有用的特性:

1、数据卷可以在容器之间共享和重用;

2、对数据卷的修改会立马有效;

3、对数据卷的更新,不会影响镜像;

4、卷会一直存在,直到没有容器使用。

5、数据卷的使用,类似于Linux下对目录或文件进行mount操作。

一、挂载本地的目录到容器里

其中-v 用来指定挂载目录,“:”前面的/data/为本地目录,“:”后面的/data1/为容器里的目录

[root@localhost ~]# touch /data/1.txt[root@localhost ~]# echo "test" > /data/1.txt[root@localhost ~]# docker exec -it 09646 bash[root@096460f831bf /]# df -hFilesystem Size Used Avail Use% Mounted on/dev/mapper/docker-253:0-1447735-096460f831bfd72b2efc6ba6b7e7bb060152afa49506ef26e0fa3cb03974f8d5 9.8G 231M 9.0G 3% /tmpfs 936M 0 936M 0% /devshm 64M 0 64M 0% /dev/shm/dev/mapper/VolGroup-lv_root 35G 6.0G 28G 18% /data1[root@096460f831bf /]# ls /data1/1.txt[root@096460f831bf /]# cat /data1/1.txttest[root@096460f831bf /]# touch /data1/2.txt[root@096460f831bf /]# exitexit[root@localhost ~]# ls /data/1.txt 2.txt

不管是把容器停掉、还是删除,数据还是存在的

二、挂载数据卷

[root@localhost ~]# docker run -itd -v /data/:/data1 centos bashe136b27a8e177d878e76c60aafade32df947a60f77b3f95dcaf0680b7ffbc6e8[root@localhost ~]# docker psCONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMESe136b27a8e17 centos "bash" 14 seconds ago Up 13 seconds tender_euclid

其实挂载目录的时候可以指定容器name,如果不指定就随机定义了。比如上面我们没有指定它,就生成了一个名字为tender_euclid,这个名字可以使用命令 Docker ps 看最右侧一列。

[root@localhost ~]# docker run -itd --volumes-from tender_euclid centos bash3222c7c5c45687e0650b699a9291bc50ecc85030acf8f388c1c6a50b0dc67164

这样我们使用centos镜像创建了新的容器,并且使用了tender_euclid容器的数据卷。

[root@localhost ~]# docker psCONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES3222c7c5c456 centos "bash" 26 seconds ago Up 25 seconds sick_albattanie136b27a8e17 centos "bash" 6 minutes ago Up 6 minutes tender_euclid[root@localhost ~]# docker exec -it 3222 bash[root@3222c7c5c456 /]# df -hFilesystem Size Used Avail Use% Mounted on/dev/mapper/docker-253:0-1447735-3222c7c5c45687e0650b699a9291bc50ecc85030acf8f388c1c6a50b0dc67164 9.8G 231M 9.0G 3% /tmpfs 936M 0 936M 0% /devshm 64M 0 64M 0% /dev/shm/dev/mapper/VolGroup-lv_root 35G 6.0G 28G 18% /data1[root@3222c7c5c456 /]# ls /data1/1.txt 2.txt[root@3222c7c5c456 /]# touch /data1/3.txt[root@3222c7c5c456 /]# ls -l /data1/total 4-rw-r--r--. 1 root root 5 Oct 20 05:53 1.txt-rw-r--r--. 1 root root 0 Oct 20 05:59 2.txt-rw-r--r--. 1 root root 0 Oct 20 06:31 3.txt[root@3222c7c5c456 /]# exitexit[root@localhost ~]# ls /data/1.txt 2.txt 3.txt

数据卷容器

一、定义数据卷容器

有时候,我们需要多个容器之间相互共享数据,类似于linux里面的NFS。所以就可以搭建一个专门的数据卷容器,然后其他容器直接挂载该数据卷。

1、建立数据卷容器

[root@localhost ~]# docker run -itd -v /data/ --name cent_testv centos bashfb45150dbc218e71ff07eca44be3603e004e01b94effcca14c2bd8b3a998f096

注意:这里的/data/是容器的/data目录,并非本地的/data/目录

[root@localhost ~]# docker psCONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMESfb45150dbc21 centos "bash" 8 minutes ago Up 8 minutes cent_testv3222c7c5c456 centos "bash" 52 minutes ago Up 52 minutes sick_albattanie136b27a8e17 centos "bash" 58 minutes ago Up 58 minutes tender_euclid[root@localhost ~]# docker exec -it cent_testv bash[root@fb45150dbc21 /]# df -hFilesystem Size Used Avail Use% Mounted on/dev/mapper/docker-253:0-1447735-fb45150dbc218e71ff07eca44be3603e004e01b94effcca14c2bd8b3a998f096 9.8G 231M 9.0G 3% /tmpfs 936M 0 936M 0% /devshm 64M 0 64M 0% /dev/shm/dev/mapper/VolGroup-lv_root 35G 6.0G 28G 18% /data[root@fb45150dbc21 /]# ls /data/[root@fb45150dbc21 /]# exitexit[root@localhost ~]# ls /data/1.txt 2.txt 3.txt

2、其他容器挂载该数据卷

[root@localhost ~]# docker run -itd --volumes-from cent_testv centos bash0a80861145c9a2627618a78db2b7225eba64137d4664d3706e02c1c623cde5e3

注意:使用–volumes-from参数所挂载数据卷的容器自身并不需要保持在运行状态

[root@localhost ~]# docker psCONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES0a80861145c9 centos "bash" 3 seconds ago Up 2 seconds mad_carsonfb45150dbc21 centos "bash" 14 minutes ago Up 14 minutes cent_testv3222c7c5c456 centos "bash" 58 minutes ago Up 58 minutes sick_albattanie136b27a8e17 centos "bash" About an hour ago Up About an hour tender_euclid[root@localhost ~]# docker exec -it 0a8086 bash[root@0a80861145c9 /]# df -hFilesystem Size Used Avail Use% Mounted on/dev/mapper/docker-253:0-1447735-0a80861145c9a2627618a78db2b7225eba64137d4664d3706e02c1c623cde5e3 9.8G 231M 9.0G 3% /tmpfs 936M 0 936M 0% /devshm 64M 0 64M 0% /dev/shm/dev/mapper/VolGroup-lv_root 35G 6.0G 28G 18% /data

利用数据卷容器迁移数据

1、数据卷的备份

[root@localhost ~]# docker run -itd --volumes-from cent_testv -v /vol_data_backup/:/backup centos bash4f5bf6f33f2c78197e54e5145824e98bf89d802376e83019c2913b336fbd9d20

首先我们需要使用cent_testv数据卷新开一个容器,同时我们还需要把本地的/vol_data_backup/目录挂载到该容器的/backup下,这样在容器中/backup目录里面新建的文件我们就可以直接在/vol_data_backup/目录中看到了。 然后再把/data/目录下面的文件打包到成data.tar文件放到/backup目录下面。

[root@localhost ~]# docker exec -it 4f5bf bash[root@4f5bf6f33f2c /]# df -hFilesystem Size Used Avail Use% Mounted on/dev/mapper/docker-253:0-1447735-4f5bf6f33f2c78197e54e5145824e98bf89d802376e83019c2913b336fbd9d20 9.8G 231M 9.0G 3% /tmpfs 936M 0 936M 0% /devshm 64M 0 64M 0% /dev/shm/dev/mapper/VolGroup-lv_root 35G 6.0G 28G 18% /data[root@4f5bf6f33f2c /]# ls /backup/[root@4f5bf6f33f2c /]# ls /data/fight.txt [root@4f5bf6f33f2c /]# tar cvf /backup/data.tar /data/tar: Removing leading `/' from member names/data//data/fight.txt[root@4f5bf6f33f2c /]# exitexit[root@localhost ~]# ls /vol_data_backup/data.tar

2、恢复

先新建一个数据卷容器,再建一个新的容器并挂载该数据卷容器,然后再把tar包解包。

[root@localhost ~]# docker run -itd -v /data --name cent_testv2 centos bash4cd696928bbe6e0aec9bf8b6856323d7228eb65006b21849eff9f0d41dcea90f[root@localhost ~]# docker run -itd --volumes-from cent_testv2 -v /vol_data_backup/:/backup centos7169e8be6d3e5836b626806696046195ed600a1f95b308495e90e6c7b15170d5[root@localhost ~]# docker exec -it 7169 bash[root@7169e8be6d3e /]# df -hFilesystem Size Used Avail Use% Mounted on/dev/mapper/docker-253:0-1447735-7169e8be6d3e5836b626806696046195ed600a1f95b308495e90e6c7b15170d5 9.8G 231M 9.0G 3% /tmpfs 936M 0 936M 0% /devshm 64M 0 64M 0% /dev/shm/dev/mapper/VolGroup-lv_root 35G 6.0G 28G 18% /data[root@7169e8be6d3e /]# ls /backup/data.tar[root@7169e8be6d3e /]# mv /backup/data.tar .[root@7169e8be6d3e /]# lsanaconda-post.log bin data.tar etc lib lost+found mnt proc run srv tmp varbackup data dev home lib64 media opt root sbin sys usr[root@7169e8be6d3e /]# tar xvf data.tardata/data/fight.txt[root@7169e8be6d3e /]# ls /data/fight.txt[root@7169e8be6d3e /]# exitexit[root@localhost ~]# ls /vol_data_backup/[root@localhost ~]#

docker为数据管理提供了充分的支持,并且,使用数据卷容器是一个不错的选择。


后面小编会分享更多devops方面的干货,感兴趣的朋友可以关注一下~

docker es持久化_docker如何保持数据持久化?其实可以考虑通过数据卷挂载的方式~...相关推荐

  1. mysql数据库文件持久化_Docker之深交Mysql持久化

    哈喽,又和大家见面了,上节提到了关注我一类的问题,虽然结果不是很理想,但是只要有一位朋友支持,我就不能放弃!好了,话不多说,开整! 在上节的Docker数据卷之Mysql持久化中,我们测试完成了关于M ...

  2. docker使用docker compose file部署项目时,实现容器卷挂载,并对容器内文件夹赋予权限

    为了能使容器内的SpringBoot项目的日志方便查看,我想用容器卷挂载的方式,将容器内生成的日志文件挂载到服务器上,实现同步,即使生成了新的镜像,依赖于compose file的配置,也能使日志在服 ...

  3. docker容器运行mysql持久化_docker容器实现数据持久化的两种方式及其区别

    前言 这篇博文是我对docker实现数据持久化几种方式的特征进行一个总结. 在docker中,它的存储文件系统是在dockerhost上原有的xfs或ext4架设了一层文件系统:overlay2(将此 ...

  4. docker es持久化_使用docker数据卷对容器数据持久化

    volume是用于对Docker容器生成和使用的数据持久化的首选机制.如果您的容器生成非持久状态数据,请考虑使用 tmpfs挂载以避免将数据永久存储在任何地方,并通过避免写入容器的可写层来提高容器的性 ...

  5. docker $PWD路径_Docker 数据持久化

    1 Docker 数据持久化简介 Docker 持久化存储的原因 Docker 持久化的两种方式(volume和volume container) Docker 持久化存储的运维 2 Docker 持 ...

  6. docker 保存 环境持久化_Docker深入浅出系列 | 容器数据持久化

    Docker深入浅出系列 | 容器数据持久化 Docker已经上市很多年,不是什么新鲜事物了,很多企业或者开发同学以前也不多不少有所接触,但是有实操经验的人不多,本系列教程主要偏重实战,尽量讲干货,会 ...

  7. docker helowin 迁移_docker-compose 安装 oracle_11g_r2 并实现数据持久化

    1,采用 docker-compose 安装 1,创建相关文件 mkdir /usr/local/docker cd /usr/local/docker mkdir oracle cd oracle ...

  8. CenOS7中使用Docker安装配置Redis(数据持久化与数据卷映射)

    场景 CentOS7中Docker的安装与配置: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/119028701 首先按照上面在 ...

  9. Docker Swarm bind 数据持久化

    Docker Swarm bind 数据持久化 bind:主要将工作节点宿主级文件或目录,同步挂载到容器中. 环境: 系统:Centos 7.4 x64 应用版本:Docker 18.09.0 管理节 ...

最新文章

  1. 乖离性暗机器人_《乖离性百万亚瑟王》国服超弩暗机器人平民通关攻略
  2. 服务器销售税率,转销售云服务器税率
  3. Love2D游戏引擎制作贪吃蛇游戏
  4. 【数据结构与算法】之深入解析“格雷编码”的求解思路与算法示例
  5. 2008年CCNA第二学期第九单元题目(2008-12-14 14:04:38)
  6. webpack打包后的文件夹是空的_vue+webpack 打包文件 404 页面空白的解决方法
  7. STA 137 Topics covered this week
  8. Mysql (21)---连接的使用
  9. npm ERR! code E404 npm ERR! 404 Not Found - GET https://registry.npmjs.com/@mlamp%2fuser-info-dropdo
  10. 简约黑板擦特效表白网源码
  11. python之if语句not in与in
  12. Vulnhub-Moneybox
  13. ipad和android平板应用,排名前100的iPad应用中只有一半支持Android平板
  14. 【coolshell酷壳】你可能不知道的Shell
  15. 时间轴_windows操作系统
  16. c# winform 不在任务栏显示,只显示任务栏图标
  17. Rufus 制作 USB 启动盘简单教程
  18. 影响SIM卡座连接器的有哪些指标?
  19. : org.xml.sax.SAXParseException; lineNumber: 18; columnNumber: 6; 注释中不允许出现字符串 --
  20. 今目标文荣演讲:主线+连接一切的力量

热门文章

  1. Keras 构建DNN 对用户名检测判断是否为非法用户名(从数据预处理到模型在线预测)...
  2. HDUOJ3549 - Flow Problem(网络流+最大流最小割+模板)
  3. U盘安装系统时黑屏! 无法进入解决办法
  4. 如何解决网络连接配置和dns异常
  5. Linux性能调优集合
  6. MySQL设置真正的UTF-8
  7. 大规模数据生成 (500万条数据)
  8. 力扣题目——217. 存在重复元素
  9. 散列函数之双重散列算法解决冲突问题
  10. 使用递归解决斐波那契数列的性能问题