Docker数据集与自定义镜像:构建高效容器的关键要素

简介: Docker数据集与自定义镜像:构建高效容器的关键要素

前言

在当今的软件开发和运维领域,容器化技术已经成为了一种趋势。Docker作为其中的佼佼者,以其轻量级、可移植性和易于管理的特性,赢得了广大开发者和运维人员的青睐。在Docker的世界里,数据集和自定义镜像是两个核心概念,它们对于构建高效、稳定的容器化应用起着至关重要的作用。

本博客将带你深入探索Docker数据集与自定义镜像的奥秘。我们将从基础概念出发,逐步深入,解析Docker数据集的存储与持久化策略,以及如何构建和优化自定义Docker镜像。无论你是Docker的新手还是有一定经验的开发者,相信都能从中获得宝贵的启示和实践经验。

在接下来的篇章中,我们将一起探讨Docker数据集的创建、挂载和管理方法,了解如何在容器之间共享和重用数据,以及如何利用数据卷实现数据的持久化存储。同时,我们还将详细介绍如何从零开始构建自定义Docker镜像,包括选择基础镜像、安装和配置软件、优化镜像大小等关键步骤。

让我们一起踏上这场关于Docker数据集与自定义镜像的探索之旅,揭开构建高效容器的秘密武器,为应用容器化之路增添更多可能!

一.数据卷

1.数据卷介绍

Docker数据卷(Docker Volume)是Docker用于存储数据的一种机制,它使得数据可以在容器之间共享和持久化。数据卷的设计目的是独立于容器的生命周期,即使容器被删除,数据卷也不会被删除。因此,数据卷可以用来保存和持久化容器的数据,以便在需要时重新使用或共享。

Docker数据卷可以看作是容器内的目录或文件,但它不属于联合文件系统(Union FileSystem),因此可以绕过联合文件系统提供的一些用于持续存储或共享数据的特性。数据卷可以在容器之间共享或重用数据,卷中的更改可以直接生效,并且数据卷中的更改不会包含在镜像的更新中。

要使用Docker数据卷,可以在运行容器时通过指定挂载数据卷的命令来创建和挂载数据卷。例如,使用`docker run -v`命令可以将宿主机的目录或文件挂载到容器的目录或文件中。在挂载数据卷时,还可以指定数据卷的读写权限,例如可读可写或只读。

除了直接挂载宿主机目录或文件作为数据卷外,Docker还提供了名为“volumes”的数据卷管理方式。使用“volumes”方式创建的数据卷由Docker管理,并且可以在多个容器之间共享和重用。这种方式的优点是数据卷的管理更加灵活和方便,可以更好地满足应用的需求。

总之,Docker数据卷是一种用于存储和持久化容器数据的机制,它可以在容器之间共享和重用数据,并提供了一些用于持续存储或共享数据的特性。通过合理使用Docker数据卷,可以更好地管理和使用Docker容器中的数据。

docker run -it --name mycentos7 centos:7 /bin/bash

2.实战

宿主机和容器共享目录

将docker中的centos的/liuzhu 目录用于 共享到宿主机中

docker run -di --name c2 -v /liuzhi:/liuzhi centos:7

容器和容器之间共享目录

docker run -di -v /home/javaxl/data/c4 --name c4 centos:7
docker run -di --volumes-from c4 --name c6 centos:7

其中c4为数据卷容器,c6为普通容器,其中c4就起到一个桥接作用,我们可以通过docker inspect查看容器的详细情况

docker inspect c4
docker inspect c6

会发现c4、c6目录挂载情况是一样的

结论:不管c4、c6在指定目录创建文件夹还是文件,都会会被共享

二.自定义镜像

1.自定义镜像介绍

自定义镜像是通过轻量应用服务器的快照或容器镜像创建的。这种镜像包含了对应轻量应用服务器的磁盘数据或容器运行环境,用户可以使用自定义镜像来创建更多包含相同配置的轻量应用服务器或容器实例,提高部署和管理的效率。

此外,自定义镜像也可以被共享至云服务器ECS,进一步通过共享镜像创建ECS实例或更换操作系统,从而实现服务器的快速复制和迁移。

总的来说,自定义镜像是一种强大的工具,它允许用户快速复制和部署他们的服务器环境,无论是用于测试、开发还是生产环境。然而,需要注意的是,虽然创建自定义镜像本身不收费,但在使用镜像创建服务器或实例时,可能会产生相关的服务器或资源费用。

2.实战

2.1自定义centos,具备vim及ifconfig作用

创建文件夹

cd /liuzhi/software

mkdir mydocker

vi mycentosDockerfile

向 mycentosDockerfile 编辑内容  

FROM centos:7
MAINTAINER liuzhi "liuzhi@qq.com"
RUN yum -y install vim
RUN yum install net-tools.x86_64 -y
CMD /bin/bash
构建镜像
docker build -f mycentosDockerfile -t javaxl/centos:v1.0 .
通过镜像运行一个容器进行测试
docker run -it --name mc1 javaxl/centos:v1.0 /bin/bash

2.2自定义tomact(文件为相对目录)

通过vi命令进行创建文件 vi mytomcatDockerfile

FROM centos:7
MAINTAINER javaxl "javaxl@qq.com"
 
ENV workerDir /home/javaxl/dockerfile/3
WORKDIR $workerDir
 
ADD jdk-8u151-linux-x64.tar.gz $workerDir
COPY apache-tomcat-8.5.20.tar.gz $workerDir
RUN tar -xvf apache-tomcat-8.5.20.tar.gz apache-tomcat-8.5.20
 
ENV JAVA_HOME $workerDir/jdk1.8.0_151
ENV CLASSPATH $JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
ENV TOMCAT_HOME $workerDir/apache-tomcat-8.5.20
ENV PATH $JAVA_HOME/bin:$TOMCAT_HOME/bin:$TOMCAT_HOME/lib:$PATH
 
EXPOSE 8080
ENTRYPOINT ["/home/javaxl/dockerfile/3/apache-tomcat-8.5.20/bin/catalina.sh","run"]
构建镜像
docker build -f mytomcatDockerfile -t javaxl/tomcat8:v1.0 .
运行容器

通过代理8080端口号的方式进行访问

docker run -di --name mt1 -P javaxl/tomcat8:v1.0

直接通过80端口号进行创建

docker run -di --name mt2 -p  8080:8080 javaxl/tomcat8:v1.0

 

相关文章
|
3月前
|
人工智能 前端开发 Docker
从本地到云端:用 Docker Compose 与 Offload 构建可扩展 AI 智能体
在 AI 智能体开发中,开发者常面临本地调试与云端部署的矛盾。本文介绍如何通过 Docker Compose 与 Docker Offload 解决这一难题,实现从本地快速迭代到云端高效扩容的全流程。内容涵盖多服务协同、容器化配置、GPU 支持及实战案例,助你构建高效、一致的 AI 智能体开发环境。
346 2
从本地到云端:用 Docker Compose 与 Offload 构建可扩展 AI 智能体
|
3月前
|
JavaScript Docker 容器
使用Docker多阶段构建优化镜像大小
使用Docker多阶段构建优化镜像大小
362 100
|
3月前
|
缓存 安全 Linux
优化Docker镜像大小的多阶段构建实践
优化Docker镜像大小的多阶段构建实践
291 99
|
3月前
|
缓存 Docker 容器
优化Docker镜像大小的五个实用技巧
优化Docker镜像大小的五个实用技巧
303 98
|
3月前
|
缓存 前端开发 Docker
Docker Layer Caching:加速你的容器构建
Docker Layer Caching:加速你的容器构建
|
3月前
|
安全 Go Docker
使用Docker多阶段构建优化镜像大小
使用Docker多阶段构建优化镜像大小
|
2月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
369 5
|
3月前
|
Java Docker 容器
使用Docker多阶段构建优化镜像大小
使用Docker多阶段构建优化镜像大小
190 8
|
4月前
|
缓存 Ubuntu Docker
Ubuntu环境下删除Docker镜像与容器、配置静态IP地址教程。
如果遇见问题或者想回滚改动, 可以重启系统.
297 16
|
4月前
|
Kubernetes Docker Python
Docker 与 Kubernetes 容器化部署核心技术及企业级应用实践全方案解析
本文详解Docker与Kubernetes容器化技术,涵盖概念原理、环境搭建、镜像构建、应用部署及监控扩展,助你掌握企业级容器化方案,提升应用开发与运维效率。
813 108

热门文章

最新文章