Docker之快速搞定容器数据卷

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 前面我们介绍了镜像和容器,通过镜像我们可以启动多个容器,但是我们发现当我们的容器停止获取删除后,我们在容器中的应用的一些数据也丢失了,这时为了解决容器的数据持久化,我们需要通过容器数据卷来解决这个问题,本文我们就来介绍下容器数据卷。


 前面我们介绍了镜像和容器,通过镜像我们可以启动多个容器,但是我们发现当我们的容器停止获取删除后,我们在容器中的应用的一些数据也丢失了,这时为了解决容器的数据持久化,我们需要通过容器数据卷来解决这个问题,本文我们就来介绍下容器数据卷。

1.是什么

 Docker容器产生的数据,如果不通过docker commit生成新的镜像,使得数据做为镜像的一部分保存下来,那么当容器删除后,数据自然也就没有了。为了能保存数据在docker中我们使用卷。简单来说,容器卷就相当于Redis中持久化方式的RDB和AOF。

2.解决了什么问题

 卷就是目录或文件,存在于一个或多个容器中,由docker挂载到容器,但不属于联合文件系统,因此能够绕过Union File System提供一些用于持续存储或共享数据的特性:

 卷的设计目的就是数据的持久化,完全独立于容器的生存周期,因此Docker不会在容器删除时删除其挂载的数据卷

特点:

   数据卷可在容器之间共享或重用数据

   卷中的更改可以直接生效

   数据卷中的更改不会包含在镜像的更新中

   数据卷的生命周期一直持续到没有容器使用它为止

   持久化,容器间继承和共享数据

3.数据卷

 首先我们来看看数据卷的使用方式

3.1 直接命令添加

3.1.1 挂载数据卷

添加的命令

docker run -it -v /宿主机绝对路径:/容器内目录 镜像名

image.png

我们发现执行了该命令后,在宿主机中会添加mydatavolume文件夹,同时在容器中的根目录中也有了datavolumecontainer文件夹。

image.png

这表示数据卷挂载成功了。同时我们也可以通过前面介绍的 docker inspect 容器名称ID来查看容器的 json数据

image.png

3.1.2 数据共享操作

 数据卷挂载成功后,我们来看看容器和宿主机之间的数据共享,我们先在宿主机的mydatavolume目录中创建一个文件。然后到容器的datavolumecontainer目录中查看是否有相同的文件,然后我们再反过来测试。

image.png

然后我们发现在容器中也有了相同的文件,而且内容也一致。反过来

image.png

这就说明容器和宿主机中的数据实现了数据共享

3.3.3 容器停止数据共享

 接下来我们把容器停止掉,然后在宿主机中更新数据,然后启动容器我们看看数据是否还能同步。

image.png

更新宿主机中的数据

image.png

启动原来的容器查看。

image.png

3.3.4 权限管理

 前面我们介绍的共享的权限是在容器中具有读写的权限。通过docker inspect 容器ID 我们也可以看到

image.png

我们可以修改该权限

docker run -it -v /宿主机绝对路径:/容器内目录:ro 镜像名

image.png

查看状态

image.png

宿主机添加文件

image.png

容器中查看

image.png

创建文件或者修改文件会失败

image.png

3.2 DockerFile添加

 DockerFile下篇文章我们会专门来介绍,此处我们先来使用看看效果。

3.2.1 mydocker文件夹

 在根目录下创建mydocker文件夹

image.png

3.2.2 VOLUM指令

VOLUME["/dataVolumeContainer","/dataVolumeContainer2","/dataVolumeContainer3"]

   说明:

   出于可移植和分享的考虑,用-v 主机目录:容器目录这种方法不能够直接在Dockerfile中实现。

   由于宿主机目录是依赖于特定宿主机的,并不能够保证在所有的宿主机上都存在这样的特定目录。

3.2.3 File构建

 构建File文件

image.png

# volume test
FROM centos
VOLUME ["/dataVolumeContainer1","/dataVolumeContainer2"]
CMD echo "finished,--------success1"
CMD /bin/bash

3.2.4 build新镜像

docker build -f /mydocker/dockerfile1 -t bobokaoya/centos .

image.png

3.2.5 run一个新容器

 根据上面新创建的镜像我们来run一个新容器

image.png

那么如此一来,对应的宿主机的映射地址在哪呢?docker inspect 容器ID来查看

image.png

容器的 共享目录中创建 文件。

image.png

去宿主中的映射目录中查看

image.png

搞定~

注意

   Docker挂载主机目录Docker访问出现cannot open directory .: Permission denied

   解决办法:在挂载目录后多加一个–privileged=true参数即可

4.数据卷容器

 命名的容器挂载数据卷,其它容器通过挂载这个(父容器)实现数据共享,挂载数据卷的容器,称之为数据卷容器,我们在前面的案例基础上来介绍

4.1 启动一个父容器

docker run -it --name dc01 bobokaoya/centos

image.png

然后在共享目录中创建文件

image.png

4.2 创建两个子容器

创建dc02

docker run -it --name dc02 --volumes-from dc01 bobokaoya/centos

image.png

同时在dc02中修改了文件

我们在创建dc03容器,同时继承dc01

docker run -it --name dc03 --volumes-from dc01 bobokaoya/centos

image.png

我们发现dc03中也看到dc02修改的数据,说明共享是成功的。

4.3 删除dc01,查看dc02和dc03是否共享

 我们停掉dc01并删除,dc02和dc03之间的数据还是共享的

image.png

dc02修改,然后查看dc03

image.png

   结论:容器之间配置信息的传递,数据卷的生命周期一直持续到没有容器使用它为止.


相关实践学习
DataV Board用户界面概览
本实验带领用户熟悉DataV Board这款可视化产品的用户界面
阿里云实时数仓实战 - 项目介绍及架构设计
课程简介 1)学习搭建一个数据仓库的过程,理解数据在整个数仓架构的从采集、存储、计算、输出、展示的整个业务流程。 2)整个数仓体系完全搭建在阿里云架构上,理解并学会运用各个服务组件,了解各个组件之间如何配合联动。 3 )前置知识要求   课程大纲 第一章 了解数据仓库概念 初步了解数据仓库是干什么的 第二章 按照企业开发的标准去搭建一个数据仓库 数据仓库的需求是什么 架构 怎么选型怎么购买服务器 第三章 数据生成模块 用户形成数据的一个准备 按照企业的标准,准备了十一张用户行为表 方便使用 第四章 采集模块的搭建 购买阿里云服务器 安装 JDK 安装 Flume 第五章 用户行为数据仓库 严格按照企业的标准开发 第六章 搭建业务数仓理论基础和对表的分类同步 第七章 业务数仓的搭建  业务行为数仓效果图  
相关文章
|
6天前
|
Ubuntu API 网络虚拟化
ubuntu22 编译安装docker,和docker容器方式安装 deepseek
本脚本适用于Ubuntu 22.04,主要功能包括编译安装Docker和安装DeepSeek模型。首先通过Apt源配置安装Docker,确保网络稳定(建议使用VPN)。接着下载并配置Docker二进制文件,创建Docker用户组并设置守护进程。随后拉取Debian 12镜像,安装系统必备工具,配置Ollama模型管理器,并最终部署和运行DeepSeek模型,提供API接口进行交互测试。
124 15
|
6天前
|
网络协议 API Docker
Docker+consul容器服务的更新与发现
通过本文的介绍,我们详细探讨了如何结合Docker和Consul来实现容器服务的更新与发现。通过Consul的服务注册和发现功能,可以高效地管理和监控容器化服务,确保系统的高可用性和可扩展性。希望本文能帮助您在实际项目中更好地应用Docker和Consul,提高系统的可靠性和管理效率。
39 23
|
1月前
|
存储 Docker 容器
Docker-基础(数据卷、自定义镜像、Compose)
通过数据卷实现持久化存储,通过自定义镜像满足特定需求,通过Docker Compose方便地管理多容器应用
87 27
|
1月前
|
存储 Docker 容器
Docker-基础(数据卷、自定义镜像、Compose)
通过数据卷实现持久化存储,通过自定义镜像满足特定需求,通过Docker Compose方便地管理多容器应用。掌握这些Docker基础概念和操作,可以显著提高开发和部署效率,确保应用程序的可移植性和可扩展性。
74 22
|
1月前
|
数据库 Docker 容器
docker容器为啥会开机自启动
通过配置适当的重启策略,Docker容器可以在主机系统重启后自动启动。这对于保持关键服务的高可用性和自动恢复能力非常有用。选择适合的重启策略(如 `always`或 `unless-stopped`),可以确保应用程序在各种情况下保持运行。理解并配置这些策略是确保Docker容器化应用可靠性的关键。
225 93
|
1月前
|
数据库 Docker 容器
docker容器为啥会开机自启动
通过配置适当的重启策略,Docker容器可以在主机系统重启后自动启动。这对于保持关键服务的高可用性和自动恢复能力非常有用。选择适合的重启策略(如 `always`或 `unless-stopped`),可以确保应用程序在各种情况下保持运行。理解并配置这些策略是确保Docker容器化应用可靠性的关键。
62 17
|
1月前
|
运维 Java 虚拟化
《docker基础篇:1.Docker简介》,包括Docker是什么、容器与虚拟机比较、能干嘛、去哪下
《docker基础篇:1.Docker简介》,包括Docker是什么、容器与虚拟机比较、能干嘛、去哪下
120 12
|
1月前
|
Ubuntu NoSQL Linux
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
160 6
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
|
1月前
|
Kubernetes Linux 虚拟化
入门级容器技术解析:Docker和K8s的区别与关系
本文介绍了容器技术的发展历程及其重要组成部分Docker和Kubernetes。从传统物理机到虚拟机,再到容器化,每一步都旨在更高效地利用服务器资源并简化应用部署。容器技术通过隔离环境、减少依赖冲突和提高可移植性,解决了传统部署方式中的诸多问题。Docker作为容器化平台,专注于创建和管理容器;而Kubernetes则是一个强大的容器编排系统,用于自动化部署、扩展和管理容器化应用。两者相辅相成,共同推动了现代云原生应用的快速发展。
199 11
|
4月前
|
安全 Shell Linux
docker进入容器命令
docker进入容器命令
136 1