Docker 容器数据卷用 DockerFile 添加 | 学习笔记

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 快速学习 Docker 容器数据卷用 DockerFile 添加

开发者学堂课程【Docker 快速入门:Docker 容器数据卷用 DockerFile 添加】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址:https://developer.aliyun.com/learning/course/616/detail/9403


Docker 容器数据卷用 DockerFile 添加

1、用命令直接添加容器数据卷,就是-v,docker run -it v / 宿主机绝对路径目录:/容器内目录: ro 镜像名。

2、第二种方法 dockerfile 添加,是什么?

JavaEE Hello. Java--->Hello.class

Docker images====>DockerFile

类比相当于是对 images 镜像的一种源码集表述,如果连续改 class,想怎么做都可以。

3、查询 tomcat。

image.png

Supported tags and respective Dockerfile links

支持的标记和相关的 Dockerfile 连接,tomcat 从 789 都给,选择 8.5.32,点开。

FROM openjdk:8-jre

DockerFile 体系结构

FROM

MAINTAINER

RUN

EXPOSE

WORKDIR

ENV

ADD

COPy

VOLUME

CMD

ENTRYPOINT

ONBUILD

from 像 java 中的 extends 继承,extends object 一个镜像不可能独立的构建,

ENV CATALINA HOME /usr/local/tomcat

任何的 linux 都有个 user/local,docker 下的就是精简版小型化的精巧版的 linux系统,比如 200 多兆的 centos。

ENV PATH $CATALINA HOME/bin:$PATH

RUN mkdir -p "$CATALINA HOME "

运行 linux 命令

NORKDIR $CATALINA_HOME

\是连接符,一行写不下,转行,代表折行。

EXPOSE 8080

当前 DockerFile 决定了镜像是什么,最终暴露出的默认端口是 8080。

CHD["catalina . sh"run]

启动 tomcat。

回到 tomcat。

image.png

输入 https://hub.docker.com/ /redis/。

image.png

点击 4.0 版。

image.png

tomcat 暴露出的端口是 8080。

EXPOSE 6379

CMD [' "redis-server "]

images 是镜像模版的描述文件,DockerFile 有自己的语法规则,类似 linux 中的脚本编程,DockerFile 是 docker 编程。

4、利用 DockerFile 完成容器卷的管理。

(1)根目录下新建 mydoqker 文件夹并进入。

目前在主机,docker ps,后台没有运行任何容器实例,

mkdir /mydocker

cd /mydocker/

Ll

Pwd

mydocker

(2)可在 Dockerfile 中使用 VOLUME 指令来给镜像添加一个或多个数据卷。

假设可以一对多,一个笔记本上可以接两个活动硬盘,三个活动硬盘,主要有足够的 usb 接口,没有任何问题。VOLUME["/dataVolumeContainer","/dataVolumeContainer2","/dataVolumeContainer3"]

宿主机的 json 串,证明可以连多个,只支持容器内

说明:

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

由于宿主机目录是依赖于特定宿主机的,并不能够保证在所有的宿主机上都存在这样的特定目录。假设在用 Dockerfile 写 abc 目录,目前机器有,但是如果把Dockerfile 放到别的机器上,别的机器没有 abc 目录,迁移就会收到影响,所以不存在。

(3)File 构建

编写 Dockerfile,就是 Dockerfile 的构建。Vim Dockerfile

像 linux 编程一样,编写 Dockerfile。

# volume test

当前自己做的 Dockerfile 来自于父类的镜像 FROM centos,extends object 或者extends user service dio。

FROM centos

在当前的 centos 中,根目录下面新建两个容器卷,data1,data2

VOLUME["/dataVolumeContainer1"," /dataVolumeContainer2" ]

cmd 在 linux 世界里,centos 打出一句话,像 java 中 system out println,logo附件,日志

CMD echo "finished ,--------success1"

某个主机的目录

CMD /bin/bash

翻译成上一讲 docker 命令方法,host 不支持,因为有迁移性

docker run  - it  -V/host1: /dataVolmeContainer1  V/host2: /dataVolumeContainer2 centos /bin/bash

所以只能在当前 centos 上面生成 data1,data2。先编写可执行的 dockerfile 脚本。

(4)build 后生成镜像,获得一个新镜像 zzyy/centos

在 docker 架构图中有 docker build 命令,build 就是 dockerfile 文件,将它 bulid 成为一个新的镜像模版。

image.png

docker build -f /mydocker/ dockerfile2 -t zzyy/ centos.

f 是 file,指明 dockerfile 在哪,-t 命名空间,镜像名字,在当前目录下面。

如果名字是 dockerfile,可以不加 -f。

docker build -f /mydocker/ dockerfile -t zzyy/ centos.

一层一层执行相关的命令,构建以当前的模版,添加了两个新功能,添加了两个容器数据卷,构建更新的镜像文件运行。镜像像花卷,是一层套一层,就像同心圆,一圈一圈套着,只访问最外层。

第一层

FRCM . centos

第二层

VOLUME["/dataVolumeContainer1","/dataVolumeContainer2"]

dockerfile 获得新的镜像 zzyy/centos,主要是为了和命名区别开。

发送上下文的 docker daemon,跟 docker 主进程沟通。

分成很多层。

Step 0 : FROM centos

--> 88ec626ba223

Step1:VOLUME/dataVolumeContainer1 /dataVolumeContainer2

-> Running in a0aebb14fd2b

--->146824fe5c32

Removing intermediate container a0aebb14 fd2b

Step 2 : CMD echo " finished, ·----·-- success1 "

---> Running ịn 5964 cbf2 fbce

---> f318b0dddb6a

Removing intermediate container 5964cbf2fbce

Step 3 : CMD /bin/bash

-> Running in 26ae67aee790

---> ee2a35672484

Removing intermediate container 26ae67aee790

最后一层一层叠加

Successfully built ee2a35672484

docker images

ee2a 开头,如果运行容器,直接就会在centos下面建两个容器卷,dataVolumeContainer1,dataVolumeContainer2,一出场就挂了两个活动硬盘。

REPOSITORY

IMAGE ID

zzyy/ centos

ee2a35672484

atguigu/ mytomcat

4db6a44256b2

mongo

ca96c146aa68

hello- world

3535063d9957

tomcat

d94da71c3a1f

centos

88ec626ba223

docker images zzyy/ centos 可以查出。

(5)run 容器

docker run - it zzyy/ centos

不写 bin/bash 也可以,容器卷会告诉执行是否成功,登陆到 cmd/bin/bash,抵消终端命令行登陆,

打出 CMD . echo . "finished, --------success1",说明容器卷运行到这一行。

image 是镜像,而现在 9cb93a45687d 是容器,pwd 进去之后,精简版 centos 中有根目录,如果运行阿里云的 centos,一开始没有容器卷,用自定义的有dataVolumeContainer1

dataVolumeContainer2

(6)通过上述步骤,容器内的卷目录地址已经知道对应的主机目录地址哪?

目前使用 dockerfile 形式在容器里面创建两个容器卷,容器卷要跟宿主机进行数据的交互和沟通,

Cd dataVolumeContainer1

Pwd

dataVolumeContainer1

touch containt01. txt

ll

在容器中创建一个,因为没有指定宿主机的绝对路径,docker 会给一个默认,打开终端,

Docker ps

Docker inspect 9cb93a45687d

/var/ lib/ docker/ Volumes/

406f208fdb961a3b471e67b95b9 d2fec4e18266c7506b3597aca22b3b8ed0244/ data

如果用 dockerfile 生成,没有指定宿主机,读写都是 true,dataVolumeContainer1 是容器内的容器卷,/var/ lib/ docker/ Volumes/406f208fdb961a3b471e67b95b9 d2fec4e18266c7506b3597aca22b3b8ed0244/ data是本地机器宿主机的,再开一个终端,

Cd/var/ lib/ docker/ Volumes/

406f208fdb961a3b471e67b95b9 d2fec4e18266c7506b3597aca22b3b8ed0244/ data

Pwd

主机上

Ll

可以看到有 containt01.txt,变相的实现宿主机到容器,容器到宿主机的数据共享。

touch host. txt

Ll

主机上有了,在容器中 ll,也有了。

(7)主机对应默认地址,跟案例一样。

5、如果有机器出现问题,确认容器卷后,不能写,如果出现以下报错。

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

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

docker run -it -v /myDataVolume : /dataVolumeContainer --privileged=true 镜像名

这就是用 dockerfile 添加数据卷。

相关实践学习
基于Hologres轻松玩转一站式实时仓库
本场景介绍如何利用阿里云MaxCompute、实时计算Flink和交互式分析服务Hologres开发离线、实时数据融合分析的数据大屏应用。
阿里云实时数仓实战 - 项目介绍及架构设计
课程简介 1)学习搭建一个数据仓库的过程,理解数据在整个数仓架构的从采集、存储、计算、输出、展示的整个业务流程。 2)整个数仓体系完全搭建在阿里云架构上,理解并学会运用各个服务组件,了解各个组件之间如何配合联动。 3 )前置知识要求   课程大纲 第一章 了解数据仓库概念 初步了解数据仓库是干什么的 第二章 按照企业开发的标准去搭建一个数据仓库 数据仓库的需求是什么 架构 怎么选型怎么购买服务器 第三章 数据生成模块 用户形成数据的一个准备 按照企业的标准,准备了十一张用户行为表 方便使用 第四章 采集模块的搭建 购买阿里云服务器 安装 JDK 安装 Flume 第五章 用户行为数据仓库 严格按照企业的标准开发 第六章 搭建业务数仓理论基础和对表的分类同步 第七章 业务数仓的搭建  业务行为数仓效果图  
相关文章
|
4天前
|
存储 安全 数据安全/隐私保护
【Docker 专栏】Docker 容器化应用的备份与恢复策略
【5月更文挑战第9天】本文探讨了Docker容器化应用的备份与恢复策略,强调了备份在数据保护、业务连续性和合规要求中的关键作用。内容涵盖备份的重要性、内容及方法,推荐了Docker自带工具和第三方工具如Portainer、Velero。制定了备份策略,包括频率、存储位置和保留期限,并详细阐述了恢复流程及注意事项。文章还提及案例分析和未来发展趋势,强调了随着技术发展,备份与恢复策略将持续演进,以应对数字化时代的挑战。
【Docker 专栏】Docker 容器化应用的备份与恢复策略
|
22小时前
|
Prometheus 监控 Cloud Native
构建高效稳定的Docker容器监控体系
【5月更文挑战第13天】在微服务架构和容器化部署日益普及的背景下,对Docker容器的监控变得尤为重要。本文将探讨一种构建高效稳定Docker容器监控体系的方法,通过集成Prometheus和cAdvisor工具,实现对容器资源使用情况、性能指标和运行状态的实时监控。同时,结合Grafana进行数据可视化,为运维人员提供直观的分析界面,以便及时发现和解决潜在问题,保障系统的高可用性和稳定性。
13 6
|
1天前
|
存储 安全 开发者
如何删除 Docker 镜像、容器和卷?
【5月更文挑战第11天】
12 2
如何删除 Docker 镜像、容器和卷?
|
3天前
|
NoSQL Redis Docker
Mac上轻松几步搞定Docker与Redis安装:从下载安装到容器运行实测全程指南
Mac上轻松几步搞定Docker与Redis安装:从下载安装到容器运行实测全程指南
14 0
|
4天前
|
缓存 关系型数据库 数据库
【Docker 专栏】Docker 与容器化数据库的集成与优化
【5月更文挑战第9天】本文探讨了Docker与容器化数据库集成的优势,如快速部署、环境一致性、资源隔离和可扩展性,并列举了常见容器化数据库(如MySQL、PostgreSQL和MongoDB)。讨论了集成方法、注意事项、优化策略,包括资源调整、缓存优化和监控告警。此外,强调了数据备份、恢复测试及性能评估的重要性。未来,随着技术发展,二者的集成将更紧密,为数据管理带来更多可能性。掌握此技术将应对数字化时代的机遇与挑战。
【Docker 专栏】Docker 与容器化数据库的集成与优化
|
4天前
|
监控 Kubernetes Docker
【Docker 专栏】Docker 容器内应用的健康检查与自动恢复
【5月更文挑战第9天】本文探讨了Docker容器中应用的健康检查与自动恢复,强调其对应用稳定性和系统性能的重要性。健康检查包括进程、端口和应用特定检查,而自动恢复则涉及重启容器和重新部署。Docker原生及第三方工具(如Kubernetes)提供了相关功能。配置检查需考虑检查频率、应用特性和监控告警。案例分析展示了实际操作,未来发展趋势将趋向更智能和高效的检查恢复机制。
【Docker 专栏】Docker 容器内应用的健康检查与自动恢复
|
4天前
|
存储 安全 数据库
【Docker 专栏】Docker 容器内应用的状态持久化
【5月更文挑战第9天】本文探讨了Docker容器中应用状态持久化的重要性,包括数据保护、应用可用性和历史记录保存。主要持久化方法有数据卷、绑定挂载和外部存储服务。数据卷是推荐手段,可通过`docker volume create`命令创建并挂载。绑定挂载需注意权限和路径一致性。利用外部存储如数据库和云服务可应对复杂需求。最佳实践包括规划存储策略、定期备份和测试验证。随着技术发展,未来将有更智能的持久化解决方案。
【Docker 专栏】Docker 容器内应用的状态持久化
|
4天前
|
机器学习/深度学习 监控 Kubernetes
【Docker 专栏】Docker 容器内服务的自动扩展与缩容
【5月更文挑战第9天】本文探讨了Docker容器服务的自动扩展与缩容原理及实践,强调其在动态业务环境中的重要性。通过选择监控指标(如CPU使用率)、设定触发条件和制定扩展策略,实现资源的动态调整。方法包括云平台集成和使用Kubernetes等框架。实践中,电商平台和实时数据处理系统受益于此技术。注意点涉及监控数据准确性、扩展速度和资源分配。未来,智能算法将提升扩展缩容的效率和准确性,成为关键技术支持。
【Docker 专栏】Docker 容器内服务的自动扩展与缩容
|
4天前
|
Java 数据库连接 Docker
【Docker 专栏】Docker 容器内环境变量的管理与使用
【5月更文挑战第9天】本文介绍了Docker容器中环境变量的管理与使用,环境变量用于传递配置信息和设置应用运行环境。设置方法包括在Dockerfile中使用`ENV`指令或在启动容器时通过`-e`参数设定。应用可直接访问环境变量或在脚本中使用。环境变量作用包括传递配置、设置运行环境和动态调整应用行为。使用时注意变量名称和值的合法性、保密性和覆盖问题。理解并熟练运用环境变量能提升Docker技术的使用效率和软件部署质量。
【Docker 专栏】Docker 容器内环境变量的管理与使用
|
5天前
|
运维 安全 Linux
深入理解Docker自定义网络:构建高效的容器网络环境
深入理解Docker自定义网络:构建高效的容器网络环境