docker-数据管理

julien 2019-12-30

前提:在docker中,一个从镜像启动的容器一旦删除后会删除对应在物理机上的数据信息。所以要做数据持久化的操作。
数据卷:(data volum)
    持久化数据
    容器这间共享数据。
选项:-v [host-dir]:[container-dir]:[rw|ro]       --volumes-from=””
如果我们在容器中或在dockerfile中写了data volum语句,并且会写个目录,比如写的是/var/www/html,那么他就会在我们宿主机上随机创建一个目录。这个目录会挂载到/var/www/html下,如果有一天docker容器被删除了,这个目录不会随着我们容器消毁而消毁。也就意味着这个目录持久化了。
如果没有在dockerfile中写或者是在dockerfile中写了又不想把他放在下面。
通过加一个-v的选项,去让他删除的时候,随着容器删除面删除,而且还可以去指定dockerfile持久化目录持久化在我们本机的哪个目录下。
1、运行一个镜像为容器
[ /]#  docker run --name mysql -p 3306:3306 -v /mysql:/var/lib/mysql -d hub.c.163.com/public/centos:6.7-tools
b6045231a2963976472024969f2d5a16541fbc900c1532dfc892013824c23f0c
[ /]# cd mysql/
[ mysql]# ls
[ mysql]# docker run --name web1 -p 80:80 -v /web1:/var/www/html -d hub.c.163.com/public/centos:6.7-tools
20e93e34080badf563e3abacae7d61cddc5496c1ec8d21aa401bd4b4646d6308
[ mysql]# cd /web1/
[ web1]# ls
[ web1]# docker ps -a
CONTAINER ID        IMAGE                                   COMMAND                  CREATED             STATUS              PORTS                            NAMES
20e93e34080b        hub.c.163.com/public/centos:6.7-tools   "/usr/bin/supervisord"   36 seconds ago      Up 33 seconds       22/tcp, 0.0.0.0:80->80/tcp       web1
b6045231a296        hub.c.163.com/public/centos:6.7-tools   "/usr/bin/supervisord"   2 minutes ago       Up 2 minutes        22/tcp, 0.0.0.0:3306->3306/tcp   mysql
[ web1]# docker run --name web2 -p 81:80 -v /web1:/var/www/html -d hub.c.163.com/public/centos:6.7-tools
8ad966f1b220103068a740a823b895932e67160c83450c1811a4fe69adf5ee9f
[ ~]# cd /web1/
[ web1]# echo "test docker volume" > index.html

进入第一个容器

[ web1]# docker exec -it web1 /bin/bash
[ /]# yum -y install httpd
[ /]# service httpd start
[ /]# curl localhost
test docker volume

进入第二个容器

[ web1]# docker exec -it web2 /bin/bash
[ /]# yum -y install httpd
[ /]# service httpd start
[ /]# curl localhost
test docker volume

对于多个容器来说我可以把他挂载到同一个目录下,实现他们的数据一至,如果这是一个web集群的话,本地磁盘足够大,就可以做到目录共享的作用。在小集群下可以这么做,但是如果web服务器很多的话不建议这么做,这样本地的磁盘io会成为一个瓶颈,可以把根下的web目录挂载成远程文件系统,容器挂载在这个远程文件系统上时操作的就是远程目录的权限,并且操作的是同一个远程文件共享。这样就可以实现数据的一至性,

 
删除容器时加上-v那么持久化目录里的内容也就删除了。
 
持久化目录有两种方式:一种是在docerfile中做volumes的声名,另一种是在启动容器时加一个-v的选项。实现的方式不一样结果也不一样,
--volumes-from=" “
比如wordpress会自己创建一个持久化目录,加了--volumes-from=" “后面可以跟上你的那个容器,你要从那个容器挂载跟他相同的
,不建议这么操作如果第一个容器删除了第二个容器可能会出问题。所以最好是先找到一个持久化目录,手动加-v把他挂载上,
 
数据卷的备份和还原。
老版本下可以在exec过程中去添加一个-v的选项,现在不行了,认为这样做不安全,新版本没这个选项了。
新版本必须在创建容器时挂载一个随机目录用于后期的数据维护和管理,对于数据库来说要一个定期的备份,这里的备份就可以在宿主机上做了,用-v把容器/var/lib/mysql目录挂载到宿主机的/mysql目录下,在宿主机的目录中写一个备份脚本,定时的到/mysql目录中备份就可以了。如果是还原的话把数据直接还原到宿主机的/mysql目录下就行了。那这个数据就被还原了。

 docker-数据管理

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

 

相关推荐