www.icesr.com
IT运维工程师的摇篮

docker数据管理

数据卷挂载

1. 挂载本地的目录到容器里
docker run -tid -v /data/:/data centos bash //-v 用来指定挂载目录,:前面的/data/为宿主机本地目录,:后面的/data/为容器里的目录,会在容器中自动创建
2. 挂载数据卷
其实我们挂载目录的时候,可以指定容器name,如果不指定就随机定义了。比如上面我们没有指定,它就生成了一个名字为suspicious_roentgen,这个名字可以使用命令 docker ps 看最右侧一列
docker run -itd –volumes-from suspicious_roentgena centos6 bash
这样,我们使用centos6镜像创建了新的容器,并且使用了suspicious_roentgen 容器的数据卷
举例:
左边是宿主机的/data目录,右边的是容器的/data/目录

<code>[root<span class="hljs-variable">@py1</span> ~]<span class="hljs-comment"># docker run -itd -v /data/:/data centos_with_net bash</span>
<span class="hljs-number">9</span>eec997ac9d0391ec359f5295e147a6e2cecf9b1fdc36986038fa1e8fd2a2d5c
[root<span class="hljs-variable">@py1</span> ~]<span class="hljs-comment"># docker exec -it 9eec99 bash</span>
[root<span class="hljs-variable">@9eec997ac9d0</span> /]<span class="hljs-comment"># ls /data/</span>
mysql-<span class="hljs-number">5.6</span>.<span class="hljs-number">36</span>  mysql-<span class="hljs-number">5.6</span>.<span class="hljs-number">36</span>-linux-glibc2.<span class="hljs-number">5</span>-x86_64.tar.gz  redis  redis2</code>

此时在容器内创建的文件 在宿主机也能看到
其他容器挂载:

<code>[root<span class="hljs-variable">@py1</span> ~]<span class="hljs-comment"># docker run -itd --volumes-from suspicious_roentgen centos6 bash</span>
<span class="hljs-number">2</span>de678d5764a09d6510d25919b167ae2966c9550c91499903f416e5c41defd1a
[root<span class="hljs-variable">@py1</span> ~]<span class="hljs-comment"># docker exec -it 2de678 bash</span>
[root<span class="hljs-variable">@2de678d5764a</span> /]<span class="hljs-comment"># ls /data/</span>
<span class="hljs-number">123132</span>  mysql-<span class="hljs-number">5.6</span>.<span class="hljs-number">36</span>  mysql-<span class="hljs-number">5.6</span>.<span class="hljs-number">36</span>-linux-glibc2.<span class="hljs-number">5</span>-x86_64.tar.gz  redis  redis2</code>

3. 定义数据卷容器
有时候,我们需要多个容器之间相互共享数据,类似于linux里面的NFS,所以就可以搭建一个专门的数据卷容器,然后其他容器直接挂载该数据卷。
首先建立数据卷容器
docker run -itd -v /data/ –name testvol centos bash //注意这里的/data/是容器的/data目录,并非本地的/data/目录。
然后让其他容器挂载该数据卷
docker run -itd –volumes-from testvol centos6 bash
如果客户端不想用/data/目录,可以用软连接指向过去

数据卷备份与恢复

备份
mkdir /data/backup
docker run –volumes-from testvol -v /data/backup/:/backup centos tar cvf /backup/data.tar /data/
说明:首先我们需要使用testvol数据卷新开一个容器,同时我们还需要把本地的/data/backup/目录挂载到该容器的/backup下,这样在容器中/backup目录里面新建的文件,我们就可以直接在/data/backup/目录中看到了。 然后再把/data/目录下面的文件打包到成data.tar文件放到/backup目录下面。
恢复
思路: 先新建一个数据卷容器,再建一个新的容器并挂载该数据卷容器,然后再把tar包解包。
新建数据卷容器:docker run -itd -v /data/ –name testvol2 centos bash
挂载数据卷新建容器,并解包:docker run –volumes-from testvol2 -v /data/backup/:/backup centos tar xf /backup/data.tar
如果容器跟宿主机直接做了映射,我们直接备份宿主机的/data/目录就可以了

未经允许不得转载:冰点网络 » docker数据管理

分享到:更多 ()

评论 抢沙发

评论前必须登录!