1.docker架构
2.docker持续化存储-数据卷
//以后台方式运行容器 (推荐)
docker run -d -v 宿主机目录/文件的绝对路径:容器内目录/文件的绝对路径[:rw/ro] -p 主机端口:容器端口 --name=容器名称 镜像ID/镜像名称[:版本号]
执行下面命令
docker run -p 1122:3306 --name mysql99 \
-v /app/mydata99/mysql/log:/var/log/mysql \
-v /app/mydata99/mysql/data:/var/lib/mysql \
-v /app/mydata99/mysql/conf:/etc/mysql \
-e MYSQL_ROOT_PASSWORD=root \
-d mysql:5.7
-v
:指定挂载主机目录/文件 到容器目录/文件 上,即挂载容器数据卷,可以使用多个-v
做多个目录或文件映射,默认为rw读写模式
,ro表示只读
。
容器被删除,容器中的数据也随之被删除。
于是便产生了需求:容器中的数据持久化** 。
容器之间 有一个**数据共享技术,将docker 中产生的 数据 同步到本地。这就是 卷技术,将容器的内目录挂载到 本地,也就是Linux 服务器上。-v参数
如下如,我在本地加一个文件,进入容器里查看也是有的,再删除容器,发现本地的文件还是在的,嗯,大概了解意思了
所有为指定具体位置的卷 都会在/app/docker/volumes/xxxx(默认 /var/lib/docker/volumes/xxxx )下的位置。
//平时使用的时候 尽量使用 指定路径挂载和 具名挂载,
-v /容器内路径 匿名挂载
-v 卷名:/容器内路径 具名挂载
-v /宿主机路径:/容器内路径 指定路径挂载
docker inspect 容器id ,挂在完成的这样哦
3 持久化的两种方式
(volume和volume container)
Docker 持久化数据包含两个方式:
一个是直接在运行的容器中直接创建volume
另一个是创建一个存储内外部映射关系的路径,然后其它容器使用-volumes-from进行引用,这种情况主要用于多个容器共享一组数据的情况。
volume
前面说的匿名和具名、指定路径
volume container
第二种创建持久化数据的方式为创建一个专门用于存储数据的容器,该容器管理持久化存储。其它容器对该容器进行引用,实现对于持久化数据的共享。
例如:创建一个/mnt为持久化路径的数据卷容器
docker create -v /mnt \
data_volume_container ubuntu
创建一个容器,引用该数据卷容器
docker run -t -i --volumes-from\
data_volume_container ubuntu /bin/bash
此时,第二个容器如果写入到/mnt,实际上写入的是第一个容器的/mnt下,也就是第一个容器/mnt映射的"母机"的路径下。
4 删除容器
删除容器时,同时删除volume
docker rm -v container-name
由于删除容器时如果不使用-v参数,往往容器会保留volume,此时如果这些volume没有任何引用的容器,就处于一个dangling的状态,下面的指令就用于删除这些卷。
1.docker volume ls -f dangling=true
2.docker volume rm <volume name>