Docker基础学习之数据管理_docker

前言

docker容器中管理数据主要有两种方式,数据卷(Data Volumes)和数据卷容器(Data Volume Containers),下面我们详细介绍Docker中的数据管理,有需要的一起来学习学习吧。

数据卷

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

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

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

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

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

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

挂载本地的目录到容器里

[root@localhost ~]# docker images
REPOSITORY     TAG     IMAGE ID   CREATED    VIRTUAL SIZE
registry      latest    5c929a8b587a  29 hours ago  33.27 MB
genesis_centos    latest    85bc3a58f134  5 days ago   277.6 MB
192.168.1.179:5000/busybox latest    9967c5ad88de  12 days ago   1.093 MB
busybox      latest    9967c5ad88de  12 days ago   1.093 MB
centos-6-x86     latest    8fca9486a39b  13 days ago   341.3 MB
centos_with_net    latest    3e8ea8607f08  4 weeks ago   294.9 MB
centos      latest    9baab0af79c4  6 weeks ago   196.7 MB
[root@localhost ~]# ls /data/
ls: 无法访问/data/: 没有那个文件或目录
[root@localhost ~]# mkdir /data/
[root@localhost ~]# docker run -itd -v /data/:/data1 centos bash
096460f831bfd72b2efc6ba6b7e7bb060152afa49506ef26e0fa3cb03974f8d5

      -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 -h
Filesystem                       Size Used Avail Use% Mounted on
/dev/mapper/docker-253:0-1447735-096460f831bfd72b2efc6ba6b7e7bb060152afa49506ef26e0fa3cb03974f8d5 9.8G 231M 9.0G 3% /
tmpfs                        936M  0 936M 0% /dev
shm                         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.txt
test
[root@096460f831bf /]# touch /data1/2.txt
[root@096460f831bf /]# exit
exit
[root@localhost ~]# ls /data/
1.txt 2.txt

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

[root@localhost ~]# docker stop 09646
09646
[root@localhost ~]# ls /data/
1.txt 2.txt
[root@localhost ~]# docker rm 09646
09646
[root@localhost ~]# ls /data/
1.txt 2.txt

挂载数据卷

[root@localhost ~]# docker run -itd -v /data/:/data1 centos bash
e136b27a8e177d878e76c60aafade32df947a60f77b3f95dcaf0680b7ffbc6e8
[root@localhost ~]# docker ps
CONTAINER ID  IMAGE    COMMAND    CREATED    STATUS    PORTS    NAMES
e136b27a8e17  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 bash
3222c7c5c45687e0650b699a9291bc50ecc85030acf8f388c1c6a50b0dc67164

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

[root@localhost ~]# docker ps
CONTAINER ID  IMAGE    COMMAND    CREATED    STATUS    PORTS    NAMES
3222c7c5c456  centos    "bash"    26 seconds ago  Up 25 seconds       sick_albattani
e136b27a8e17  centos    "bash"    6 minutes ago  Up 6 minutes       tender_euclid
[root@localhost ~]# docker exec -it 3222 bash
[root@3222c7c5c456 /]# df -h
Filesystem                       Size Used Avail Use% Mounted on
/dev/mapper/docker-253:0-1447735-3222c7c5c45687e0650b699a9291bc50ecc85030acf8f388c1c6a50b0dc67164 9.8G 231M 9.0G 3% /
tmpfs                        936M  0 936M 0% /dev
shm                         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 /]# exit
exit
[root@localhost ~]# ls /data/
1.txt 2.txt 3.txt

数据卷容器

定义数据卷容器

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

首先建立数据卷容器

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

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

[root@localhost ~]# docker ps
CONTAINER ID  IMAGE    COMMAND    CREATED    STATUS    PORTS    NAMES
fb45150dbc21  centos    "bash"    8 minutes ago  Up 8 minutes       cent_testv
3222c7c5c456  centos    "bash"    52 minutes ago  Up 52 minutes       sick_albattani
e136b27a8e17  centos    "bash"    58 minutes ago  Up 58 minutes       tender_euclid
[root@localhost ~]# docker exec -it cent_testv bash
[root@fb45150dbc21 /]# df -h
Filesystem                       Size Used Avail Use% Mounted on
/dev/mapper/docker-253:0-1447735-fb45150dbc218e71ff07eca44be3603e004e01b94effcca14c2bd8b3a998f096 9.8G 231M 9.0G 3% /
tmpfs                        936M  0 936M 0% /dev
shm                         64M  0 64M 0% /dev/shm
/dev/mapper/VolGroup-lv_root                  35G 6.0G 28G 18% /data
[root@fb45150dbc21 /]# ls /data/
[root@fb45150dbc21 /]# exit
exit
[root@localhost ~]# ls /data/
1.txt 2.txt 3.txt

其他容器挂载该数据卷

[root@localhost ~]# docker run -itd --volumes-from cent_testv centos bash
0a80861145c9a2627618a78db2b7225eba64137d4664d3706e02c1c623cde5e3

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

[root@localhost ~]# docker ps
CONTAINER ID  IMAGE    COMMAND    CREATED    STATUS    PORTS    NAMES
0a80861145c9  centos    "bash"    3 seconds ago  Up 2 seconds       mad_carson
fb45150dbc21  centos    "bash"    14 minutes ago  Up 14 minutes       cent_testv
3222c7c5c456  centos    "bash"    58 minutes ago  Up 58 minutes       sick_albattani
e136b27a8e17  centos    "bash"    About an hour ago Up About an hour      tender_euclid
[root@localhost ~]# docker exec -it 0a8086 bash
[root@0a80861145c9 /]# df -h
Filesystem                       Size Used Avail Use% Mounted on
/dev/mapper/docker-253:0-1447735-0a80861145c9a2627618a78db2b7225eba64137d4664d3706e02c1c623cde5e3 9.8G 231M 9.0G 3% /
tmpfs                        936M  0 936M 0% /dev
shm                         64M  0 64M 0% /dev/shm
/dev/mapper/VolGroup-lv_root                  35G 6.0G 28G 18% /data
[root@0a80861145c9 /]# touch /data/fight.txt
[root@0a80861145c9 /]# exit
exit
[root@localhost ~]# docker exec -it cent_testv bash
[root@fb45150dbc21 /]# ls /data/
fight.txt
[root@fb45150dbc21 /]# exit
exit

利用数据卷容器迁移数据

数据卷的备份

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

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

[root@localhost ~]# docker exec -it 4f5bf bash
[root@4f5bf6f33f2c /]# df -h
Filesystem                       Size Used Avail Use% Mounted on
/dev/mapper/docker-253:0-1447735-4f5bf6f33f2c78197e54e5145824e98bf89d802376e83019c2913b336fbd9d20 9.8G 231M 9.0G 3% /
tmpfs                        936M  0 936M 0% /dev
shm                         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 /]# exit
exit
[root@localhost ~]# ls /vol_data_backup/
data.tar

恢复

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

[root@localhost ~]# docker run -itd -v /data --name cent_testv2 centos bash
4cd696928bbe6e0aec9bf8b6856323d7228eb65006b21849eff9f0d41dcea90f
[root@localhost ~]# docker run -itd --volumes-from cent_testv2 -v /vol_data_backup/:/backup centos
7169e8be6d3e5836b626806696046195ed600a1f95b308495e90e6c7b15170d5
[root@localhost ~]# docker exec -it 7169 bash
[root@7169e8be6d3e /]# df -h
Filesystem                       Size Used Avail Use% Mounted on
/dev/mapper/docker-253:0-1447735-7169e8be6d3e5836b626806696046195ed600a1f95b308495e90e6c7b15170d5 9.8G 231M 9.0G 3% /
tmpfs                        936M  0 936M 0% /dev
shm                         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 /]# ls
anaconda-post.log bin data.tar etc lib lost+found mnt proc run srv tmp var
backup    data dev  home lib64 media  opt root sbin sys usr
[root@7169e8be6d3e /]# tar xvf data.tar
data/
data/fight.txt
[root@7169e8be6d3e /]# ls /data/
fight.txt
[root@7169e8be6d3e /]# exit
exit
[root@localhost ~]# ls /vol_data_backup/
[root@localhost ~]#

总结

docker为数据管理提供了充分的支持,并且,使用数据卷容器是一个不错的选择。以上就是这篇文章的全部内容了,希望能对大家的学习或者工作带来一定的帮助,如果有疑问大家可以留言交流。

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索数据库
, 管理
, docker
数据卷
,以便于您获取更多的相关知识。

时间: 2024-08-01 15:47:47

Docker基础学习之数据管理_docker的相关文章

Docker基础命令详解_docker

docker基本概念 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上. Docker是一个重新定义了程序开发测试.交付和部署过程的开放平台,Docker则可以称为构建一次,到处运行,这就是docker提出的"Build once,Run anywhere" 创建镜像 创建镜像的方法有三种: 基于已有的容器创建 基于本地模板导入 基于dockerfile 基于已有的容器创建 主要使用docker

【技术干货】Docker精华学习资料集锦,老司机快上车

Docker是一个开源的应用容器引擎,提供了一种在安全.可重复的环境中自动部署软件的方式,允许开发者将他们的应用和依赖包打包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化.容器完全使用沙箱机制,相互之间不会有任何接口.几乎没有性能开销,可以很容易地在机器和数据中心中运行.重要的是,它不依赖于任何语言.框架或包装系统. 正如Docker的logo一样,Docker的思想就是源于集装箱,集装箱解决了各种型号.规格的货物在各种运输工具上进行运输的问题,而集装箱和集装箱之间

Docker安装和基础用法 Docker入门教程第二篇_docker

本系列文章将介绍Docker的有关知识: (1)Docker 安装及基本用法 (2)Docker 镜像 (3)Docker 容器的隔离性 - 使用 Linux namespace 隔离容器的运行环境 (4)Docker 容器的隔离性 - 使用 cgroups 限制容器使用的资源 (5)Docker 网络 1. 安装 1.1 在 Ubuntu 14.04 上安装 Docker 前提要求: 内核版本必须是3.10或者以上 依次执行下面的步骤: sudo apt-get update sudo apt

Docker基础:查找镜像和运行容器

本文讲的是Docker基础:查找镜像和运行容器[编者的话]本文是作者学习Docker的笔记,涉及在Windows上的安装,介绍了镜像和容器的知识和基本操作,适合Docker初学者. [3 天烧脑式容器存储网络训练营 | 深圳站]本次培训以容器存储和网络为主题,包括:Docker Plugin.Docker storage driver.Docker Volume Pulgin.Kubernetes Storage机制.容器网络实现原理和模型.Docker网络实现.网络插件.Calico.Cont

Docker基础技术:Linux Namespace【上】

点点收获: //之前发现Coolshell上好久不更新了, 博主果然去搞大业去了,只恨这几篇文章看到太晚了啊~太厉害了. 1.  clone(), unshare(), setns()初识; 主要是š三个系统调用 šclone() - 实现线程的系统调用,用来创建一个新的进程,并可以通过设计上述参数达到隔离. šunshare() - 使某进程脱离某个namespace šsetns() - 把某进程加入到某个namespace 2.  学习了一个命令 -- ipcs -- report XSI

Docker基础:连接容器

本文讲的是Docker基础:连接容器[编者的话]本文是作者学习Docker的笔记,介绍了Docker上的网络,并提供了例子. [3 天烧脑式容器存储网络训练营 | 深圳站]本次培训以容器存储和网络为主题,包括:Docker Plugin.Docker storage driver.Docker Volume Pulgin.Kubernetes Storage机制.容器网络实现原理和模型.Docker网络实现.网络插件.Calico.Contiv Netplugin.开源企业级镜像仓库Harbor

分布式基础学习【一】 —— 分布式文件系统

分布式基础学习 所谓分布式,在这里,很狭义的指代以Google的三驾马车,GFS.Map/Reduce.BigTable 为框架核心的分布式存储和计算系统.通常如我一样初学的人,会以Google这几份经典的论 文作为开端的.它们勾勒出了分布式存储和计算的一个基本蓝图,已可窥见其几分风韵,但 终究还是由于缺少一些实现的代码和示例,色彩有些斑驳,缺少了点感性.幸好我们还有 Open Source,还有Hadoop.Hadoop是一个基于Java实现的,开源的,分布式存储和计算的项 目.作为这个领域最

C#的基础学习

这是一篇C#的基础学习文章,高手就可以跳过了, 1.基本类型: 基本与C\C++相同 decimal decimal是一个128位的高精度浮点数. bool 注意的是bool类型只有true和faulse两个可取值,在C#中,不能将bool值强制转换为整形值.如,将true转换为1或将1,0转换为bool值都是不行的. Parse和TryParse转换字符串 基本的数字类型包含Parse和TryParse的方法,可将数字字符串类型转换为指定的数字类型,例如 int iParse = Int32.

IOS基础学习UIButton使用详解

  UIButton按钮是IOS开发中最常用的控件,作为IOS基础学习教程知识 ,初学者需要了解其基本定义和常用设置,以便在开发在熟练运用. 第一.UIButton的定义 UIButton *button=[[UIButton buttonWithType:(UIButtonType); 能够定义的button类型有以下6种, typedef enum { UIButtonTypeCustom = 0, 自定义风格 UIButtonTypeRoundedRect, 圆角矩形 UIButtonTy