Ubantu docker学习笔记(六)容器数据卷

文章介绍了Docker容器数据卷的概念及其重要性,包括如何通过命令行和Dockerfile挂载数据卷,数据卷的容器共享,以及如何备份和恢复数据卷。此外,还详细阐述了数据卷的管理和生命周期,如与容器的关联和命令行管理数据卷的方法。
摘要由CSDN通过智能技术生成


一、容器数据卷

由于我们rootfs机制与我们的namespce,构建出来的文件分离系统,会导致我们产生数据文件,但是数据文件会随着我们容器的关闭而关闭,但是我们用户希望我们所产生的数据可以持久化,不同容器之间可以互通,也就是我们容器数据卷要解决的问题。
Docker绑定的就是Linux的绑定挂在机制,允许用户将一个目录或者文件挂载到一个文件系统中,原挂载点会被隐藏没有任何影响,从而实现共享。

(1)容器启动时初始化,如果容器使用的镜像包含数据卷,这些数据也会复制到数据卷中。
(2)容器对数据卷的修改是直接生效的。
(3)数据卷的变化不会影响镜像的更新。数据卷独立于联合文件系统,像基于联合文件系统,镜像与数据卷不会相互影响。
(4)数据卷是宿主机中的一个目录,与容器生命周期隔离。

二、容器卷挂载

2.1 在命令行挂载数据卷

使用-v加载一个数据卷

docker run -it --name volume -v /web/app centos
ls web/
exit

在这里插入图片描述
然后我们就可以通过如下命令看到挂载信息啦

docker inspect volume

在这里插入图片描述

我们再来看一个后台运行的列子

docker run -it -d --name test -v /webapp:/app nginx
docker inspect test 

在这里插入图片描述

下面,我们来进行一下测试吧
重启启动一个

docker run -it --name volume2 -v /webapp:/app centos
ls /

我们另外开一个控制台
在我们宿主机上进入webapp这个目录,然后新建两个文件

sudo su
cd /webapp
touch c.txt d.txt
ls

然后返回我们容器进行观察

ls /app

很明显进行了挂载
在这里插入图片描述
同理,我们如果在容器里面创建,我们本机也会进行更新,有点类似于我们的共享目录,这样在我们启动多台容器时,可以进行数据共享
在这里插入图片描述
此项操作,我们一般用于配置文件的共享,为了避免容器内部修改,我们会对文件进行权限设置
加入只读属性ro

docker run -it --name volume3 -v /webapp:/app:ro centos
ls /
cd app
echo hello world >a.txt

可以看到
在这里插入图片描述
同样对于创建文件也是同理,因为我们添加了只读属性

2.2 通过dockerfile挂载数据卷

dockerfile可以创建多个数据卷,但是不能映射到本地已经有的目录,在启动容器时,才会创建dockefile中指定的数据卷,然后以dockerfile中指定名称命名,所创建地址不一样,容器没有办法共享数据。

vim Dockerfile
#选择使用的image
FROM centos/vim
#执行的命令
VOLUME /root/data
VOLUME /work
VOLUME test
docker build -t volume .
ls

在这里插入图片描述
ctrl+p+q暂停退出

docker inspect 3dad75

现在就可以看到我们容器的挂载啦
在这里插入图片描述

三、数据卷容器

运行容器时宿主机会随机生成挂载目录,无法保持地址一致性,所以无法容器数据共享。数据卷,可以将已经命名的容器挂载数据卷,其他容器再通过挂载这个容器数据实现共享,挂载数据的容器的叫做容器数据卷。

docker run -it --name volume-container -v /volume1 -v /volume2 centos
ctrl+p+q暂停退出
docker inspect volume-container | grep volume

在这里插入图片描述
我们就可以看到我们所在的这个目录

cd /var/lib/docker/volumes/1f889275343587271abe22ec55878fefd25bec783e5c0ba30624fc4989893989/_data
echo hello world > a.txt
echo hello world2 > b.txt

然后我们再回到我们容器

docker attach b38d15

在这里插入图片描述
我们就可以在这里看到我们刚刚的容器目录啦
在这里插入图片描述
删除之后还是会继续保存

四、备份数据卷

人们通常会对数据进行一次或者多次备份,以确保数据的安全,下面我们来试一试吧

docker run -it --name volume-container -v /var/volume1 -v /var/volume2 centos

在其数据卷下创建文件并添加内容

echo hello world1 > /var/volume1/a.txt
echo hello world2 > /var/volume2/b.txt

我们备份的话,简单的来说,就是用–volumes-from参数来挂载数据卷,从宿主机挂载要放在备份数据的目录到容器的备份目录,然后用–rm删除容器

docker run --rm --volumes-from volume-container(你要备份的容器名)   -v /root/backup:/backup centos tar cvf /backup/backup1.tar /var/volume1

docker run --rm --volumes-from volume-container(你要备份的容器名)   -v /root/backup:/backup centos tar cvf /backup/backup2.tar /var/volume2

在这里插入图片描述

五、数据卷的恢复和迁移

5.1 恢复数据卷

由于我们之前已经对于数据卷做好了恢复,下面我们来对模拟的数据卷来进行恢复
进入数据卷

docker attach volume-container
rm -rf /var/volume1/a.txt
rm -rf /var/volume2/b.txt

然后我们用代码来恢复

docker run --rm --volumes-from volume-container -v /root/backup/:/backup centos tar xvf /backup/backup1.tar -C /

docker run --rm --volumes-from volume-container -v /root/backup/:/backup centos tar xvf /backup/backup2.tar -C /

在这里插入图片描述
完成!

5.2 迁移数据卷

我们新建一个数据卷容器

docker run -it --name new-container -v /volume1 -v /volume2 centos
ctrl+p+q
docker run --rm --volumes-from new-container -v /root/backup/:/backup centos tar xvf /backup/backup1.tar -C /volume1 
docker run --rm --volumes-from new-container -v /root/backup/:/backup centos tar xvf /backup/backup2.tar -C /volume2

在这里插入图片描述
在容器路劲和原来路劲相同时,可以直接导入,-C后面不用加参数,但是如果和源路劲不一样,我们需要在—C后面指定参数,不然会迁移失败

六、管理数据卷

6.1 与容器关联

命令含义
docker rm -v删除容器时添加-v会将数据卷一起删除
docker rm --rm运行结束时数据卷会和容器一起删除

(1)例子一

docker run -it -v /data --name test centos
docker inspect test | grep Source

在这里插入图片描述
进入到你那个目录

cd /var/lib/docker/volumes/22df6c5c6990231a9983cd9646a9115a3a5cd3bdd3260f187896205aa53036df/_data
docker rm test
docker inspect test | grep Source

可以看到数据卷还在
在这里插入图片描述

(2)例子二

docker run -it -v /data --name test2 centos
docker inspect test2 | grep Source
docker stop test2
docker rm -v test2

可以看到数据卷也随之删除
在这里插入图片描述

(3)例子三

docker run -it --rm -v /data --name test2 centos

退出容器时会自动删除容器和数据卷

6.2 命令管理

命令含义
creat创建容器卷 docker volume creat test
ls列出容器卷 docker volume ls
inspect显示一个或者多个数据卷的详细信息 docker inspect 容器名
rm删除一个或者多个容器
prune暂停容器 docker volume prune

Ubantu docker学习笔记(六)实验补充

Docker 是一种开源的容器化平台,它可以让开发者将应用程序及其依赖项打包到一个可移植的容器,然后在任何支持 Docker 的平台上运行这些容器。本文将介绍 Docker 基础知识和使用方法。 ## 安装 Docker Docker 官方提供了不同平台的安装包,可以在官网上选择对应平台的安装包进行下载。安装完成后,可以在命令行输入 `docker version` 命令来验证 Docker 是否安装成功。 ## 镜像和容器 Docker 的核心概念是镜像和容器。镜像是一个只读的模板,它包含了运行应用程序所需的所有信息,如代码、运行时环境、库文件、环境变量等。容器则是从镜像启动的运行实例,它可以被启动、停止、删除,并且可以与其他容器进行通信。 ### 镜像 Docker 镜像可以使用 `docker pull` 命令从 Docker Hub 上下载,也可以使用 `docker build` 命令从 Dockerfile 构建。一个 Dockerfile 是一个包含构建 Docker 镜像所需的指令的文本文件。 例如,下面是一个构建一个基于 Ubuntu 操作系统的 Docker 镜像的 Dockerfile: ``` # 使用 Ubuntu 作为基础镜像 FROM ubuntu:latest # 设置镜像的作者 MAINTAINER yourname # 更新 Ubuntu 系统 RUN apt-get update # 安装必要的软件 RUN apt-get install -y nginx # 复制本地文件到镜像 COPY index.html /var/www/html/ # 暴露容器端口 EXPOSE 80 # 设置容器启动命令 CMD ["nginx", "-g", "daemon off;"] ``` 使用 `docker build` 命令来构建 Docker 镜像: ``` $ docker build -t myimage . ``` ### 容器 使用 `docker run` 命令可以启动一个容器。例如,启动上面构建的 `myimage` 镜像: ``` $ docker run -d -p 8080:80 myimage ``` 其 `-d` 表示在后台运行容器,`-p` 表示将容器的端口映射到主机的端口,`myimage` 是要启动的镜像名称。 使用 `docker ps` 命令可以查看当前正在运行的容器。使用 `docker stop` 命令可以停止容器。 ## Docker Compose Docker Compose 是一个工具,它可以定义和运行多个 Docker 容器。它使用 YAML 文件来配置应用程序的服务。例如,下面是一个简单的 Docker Compose 配置文件: ``` version: '3' services: web: build: . ports: - "5000:5000" redis: image: "redis:alpine" ``` 使用 `docker-compose up` 命令可以启动这个应用程序。使用 `docker-compose down` 命令可以停止应用程序并删除容器。 ## 总结 本文介绍了 Docker 的基础知识和使用方法,包括镜像、容器Docker Compose。希望对你有所帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

叫我小唐就好了

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值