06容器的数据管理

Docker数据管理

容器中的管理数据主要有两种方式:

方式 描述 特性
1:数据卷(Data Volumes) 容器内数据直接映射到本地主机的目录,类似于挂载 1:数据卷可以在容器之间共享和重用
2:对数据卷内数据的修改会立马生效,无论是容器内操作还是本地操作
3:对数据卷的更新不会影响镜像,解耦开应用和数据
4:卷会一直存在,直到没有容器使用,可以安全地卸载它
2:数据卷容器(Data Volume Containers) 使用特定容器维护数据卷 1:多个容器之间共享一些会持续更新的数据

查看帮助文档

[root@docker ~]# docker volume --help

Usage:  docker volume COMMAND

Manage volumes

Commands:
  create      Create a volume
  inspect     Display detailed information on one or more volumes
  ls          List volumes
  prune       Remove all unused local volumes
  rm          Remove one or more volumes

或者:
[root@docker ~]# man docker-volume-create    #查看子命令

一:数据卷操作

1:创建数据卷
[root@docker ~]# docker volume create -d local  test
test
#-d, --driver="local" :Specify volume driver name

# /var/lib/docker/volumes会有一个创建的数据卷
[root@docker volumes]# ls -l /var/lib/docker/volumes/
total 24
-rw------- 1 root root 32768 Nov 16 13:37 metadata.db
drwxr-xr-x 3 root root    18 Nov 16 13:37 test

2:绑定数据卷:在创建容器的时候将主机的本地任意路径  挂载到 容器内作为数据卷
2.1:
[root@docker ~]# docker pull training/webapp
Using default tag: latest
latest: Pulling from training/webapp
Image docker.io/training/webapp:latest uses outdated schema1 manifest format. Please upgrade to a schema2 image for better future compatibility. More information at https://docs.docker.com/registry/spec/deprecated-schema-v1/
e190868d63f8: Pull complete 
909cd34c6fd7: Pull complete 
0b9bfabab7c1: Pull complete 
a3ed95caeb02: Pull complete 
10bbbc0fc0ff: Pull complete 
fca59b508e9f: Pull complete 
e7ae2541b15b: Pull complete 
9dd97ef58ce9: Pull complete 
a4c1b0cb7af7: Pull complete 
Digest: sha256:06e9c1983bd6d5db5fba376ccd63bfa529e8d02f23d5079b8f74a616308fb11d
Status: Downloaded newer image for training/webapp:latest

2.2:创建目录
[root@docker ~]# mkdir /webapp

2.3:绑定本地目录/webapp到容器的/opt/webapp目录
[root@docker /]# docker run -d -P --name web --mount type=bind,source=/webapp,destination=/opt/webapp training/webapp python app.py
ff6c0af55c8b73fa4b117d067280d53aca423e1bd658b65e445114e85fe6d3da
#-P[大写]:在宿主机上通过随机端口映射容器内启用端口
#-d:run the container in the background and print the new container ID
#本地目录必须是绝对路径,容器路径没有就会自动创建

#不建议使用training/webapp测试,创建数据卷之后,死活不能再进入容器
#使用
ubuntu@ubuntu:~$ sudo docker run -d -p 82:80 -v /src/webapp:/opt/webapp nginx
245633eb9cea1a5833ff3e6b74b2905f11890f604d7c45e2fc3ec8f6aef2dfc2
ubuntu@ubuntu:~$ docker ps -al
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                   NAMES
245633eb9cea        nginx               "nginx -g 'daemon of…"   5 seconds ago       Up 4 seconds        0.0.0.0:82->80/tcp      trusting_goldberg
ubuntu@ubuntu:~$ docker exec -it 2456 /bin/bash   #进入容器,并打开一个shell交互伪终端
root@245633eb9cea:/# ls
bin   dev  home  lib64  mnt  proc  run   srv  tmp  var
boot  etc  lib   media  opt  root  sbin  sys  usr
root@245633eb9cea:/# cd opt/
root@245633eb9cea:/opt# ls
webapp
root@245633eb9cea:/opt# cd webapp/
root@245633eb9cea:/opt/webapp# ls
root@245633eb9cea:/opt/webapp# touch test
root@245633eb9cea:/opt/webapp# echo "I love you " >>test 
root@245633eb9cea:/opt/webapp# 

#重新开一个终端
ubuntu@ubuntu:~$ cd /src/webapp/
ubuntu@ubuntu:/src/webapp$ cat test 
I love  you 


下面这条命令效果一样:-v参数
#格式: docker -it -v /宿主机绝对路径:/容器内目录  镜像
[root@docker /]# docker run -d -P --name web -v /webapp:/opt/webapp training/webapp python app.py
           

二:数据卷容器:

1:创建一个数据卷容器dbdata,并将其中一个数据卷挂载到容器内的/dbdata
[root@docker /]# docker run -it -v /dbdata --name dbdata  ubuntu:18.04
root@075058f48803:/# cd /dbdata/
root@075058f48803:/dbdata# ls
#v|--volume[=[[HOST-DIR:]CONTAINER-DIR[:OPTIONS]]]
#The CONTAINER-DIR must be an absolute path such
# /dbdata 是容器内的路径  

2:使用--volumes-from 来挂载dbdata容器中的数据卷
[root@docker /]# docker run -it --volumes-from dbdata --name db1 ubuntu:18.04
root@47a22834f404:/# ls
bin  boot  dbdata  dev  etc  home  lib  lib64  media  mnt  opt  proc  root  run  sbin  srv  sys  tmp  usr  var
root@47a22834f404:/# cd /dbdata/
root@47a22834f404:/dbdata# ls
[root@docker /]# docker run -it --volumes-from dbdata --name db2 ubuntu:18.04

# 容器db1和容器db2都挂载到同一个数据卷到相同的/dbdata目录,三个容器共享这个目录。



[root@docker /]# docker start 47a22834f404    #启动一个退出的容器
[root@docker /]# docker exec  -it 47a22834f404 /bin/bash      #进入一个已经运行的容器。

三:利用容器来迁移数据

1:备份:使用下面的命令来备份dbdata数据卷容器-内的-数据卷
[root@docker /]# docker run --volumes-from dbdata -v $(pwd):/backup --name worker ubuntu:18.04 tar -cvf /backup/backup.tar /dbdata
tar: Removing leading `/' from member names
/dbdata/
/dbdata/zz

#创建一个容器,挂载,tar包到新创建的容器内,实现迁移
#1:利用ubuntu镜像创建了一个容器worker。使用--volumes-from dbdata参数来让worker容器挂载dbdata容器的数据卷(即dbdata数据卷)
#2:使用-v $(pwd):/backup参数来挂载本地的当前目录 到worker容器的/backup目录
#3:worker容器启动后,使用tar cvf /backup/backup.tar /dbdata命令将/dbdata下内容备份为容器内的/backup/backup.tar

2:恢复:如果要恢复数据到一个容器,可以按照下面的操作
#首先创建一个带有数据卷的容器dbdata2
[root@docker /]# docker run -v /dbdata --name dbdata2 ubuntu:18.04 /bin/bash
[root@docker /]# ls -l backup.tar    #本地当前目录的文件backup.tar 
-rw-r--r-- 1 root root 10240 Nov 16 14:35 backup.tar  

[root@docker /]#  docker run -itd --volumes-from dbdata2 -v  $(pwd):/backup  busybox  tar xvf    /backup/backup.tar
Unable to find image 'busybox:latest' locally
latest: Pulling from library/busybox
Digest: sha256:1303dbf110c57f3edf68d9f5a16c082ec06c4cf7604831669faf2c712260b5a0
Status: Downloaded newer image for busybox:latest
dbdata/
dbdata/zz


#使用-v $(pwd):/backup参数来挂载本地的当前目录 到busybox容器的/backup目录

# 查看/验证恢复的数据,可以再启动一个容器挂载同样的容器卷来查看

[root@docker /]# docker run --volumes-from dbdata2 busybox /bin/ls /dbdata
zz


 docker run --volumes-from dbdata2 -v  $(pwd):/backup  busybox  tar xvf    /backup/backup.tar

原文地址:https://www.cnblogs.com/zhoujun007/p/11873383.html