docker学习笔记03-持久化存储

2023-12-28 16:59:18

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>

文章来源:https://blog.csdn.net/qq_63693805/article/details/135261586
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。