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

 

相关文章
|
12天前
|
NoSQL Java Linux
《docker高级篇(大厂进阶):2.DockerFile解析》包括:是什么、DockerFile构建过程解析、DockerFile常用保留字指令、案例、小总结
《docker高级篇(大厂进阶):2.DockerFile解析》包括:是什么、DockerFile构建过程解析、DockerFile常用保留字指令、案例、小总结
166 75
|
26天前
|
监控 NoSQL 时序数据库
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
189 77
|
8天前
|
搜索推荐 安全 数据安全/隐私保护
7 个最能提高生产力的 Docker 容器
7 个最能提高生产力的 Docker 容器
75 35
|
1月前
|
监控 Docker 容器
在Docker容器中运行打包好的应用程序
在Docker容器中运行打包好的应用程序
|
7天前
|
Ubuntu Linux 开发工具
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
Docker 是一个开源的容器化平台,允许开发者将应用程序及其依赖项打包成标准化单元(容器),确保在任何支持 Docker 的操作系统上一致运行。容器共享主机内核,提供轻量级、高效的执行环境。本文介绍如何在 Ubuntu 上安装 Docker,并通过简单步骤验证安装成功。后续文章将探讨使用 Docker 部署开源项目。优雅草央千澈 源、安装 Docker 包、验证安装 - 适用场景:开发、测试、生产环境 通过以上步骤,您可以在 Ubuntu 系统上成功安装并运行 Docker,为后续的应用部署打下基础。
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
|
1月前
|
Docker 容器
将本地的应用程序打包成Docker镜像
将本地的应用程序打包成Docker镜像
|
2天前
|
供应链 监控 安全
对话|企业如何构建更完善的容器供应链安全防护体系
随着云计算和DevOps的兴起,容器技术和自动化在软件开发中扮演着愈发重要的角色,但也带来了新的安全挑战。阿里云针对这些挑战,组织了一场关于云上安全的深度访谈,邀请了内部专家穆寰、匡大虎和黄竹刚,深入探讨了容器安全与软件供应链安全的关系,分析了当前的安全隐患及应对策略,并介绍了阿里云提供的安全解决方案,包括容器镜像服务ACR、容器服务ACK、网格服务ASM等,旨在帮助企业构建涵盖整个软件开发生命周期的安全防护体系。通过加强基础设施安全性、技术创新以及倡导协同安全理念,阿里云致力于与客户共同建设更加安全可靠的软件供应链环境。
|
19天前
|
NoSQL PHP MongoDB
docker push推送自己搭建的镜像
本文详细介绍了如何搭建和复盘两个Web安全挑战环境:人力资源管理系统和邮件管理系统。首先,通过Docker搭建MongoDB和PHP环境,模拟人力资源管理系统的漏洞,包括nosql注入和文件写入等。接着,复盘了如何利用这些漏洞获取flag。邮件管理系统部分,通过目录遍历、文件恢复和字符串比较等技术,逐步绕过验证并最终获取flag。文章提供了详细的步骤和代码示例,适合安全研究人员学习和实践。
44 3
docker push推送自己搭建的镜像
|
13天前
|
Unix Linux Docker
CentOS停更沉寂,RHEL巨变限制源代:Docker容器化技术的兴起助力操作系统新格局
操作系统是计算机系统的核心软件,管理和控制硬件与软件资源,为用户和应用程序提供高效、安全的运行环境。Linux作为开源、跨平台的操作系统,具有高度可定制性、稳定性和安全性,广泛应用于服务器、云计算、物联网等领域。其发展得益于庞大的社区支持,多种发行版如Ubuntu、Debian、Fedora等满足不同需求。
39 4
|
25天前
|
供应链 安全 Cloud Native
阿里云容器服务助力企业构建云原生软件供应链安全
本文基于2024云栖大会演讲,探讨了软件供应链攻击的快速增长趋势及对企业安全的挑战。文中介绍了如何利用阿里云容器服务ACK、ACR和ASM构建云原生软件供应链安全,涵盖容器镜像的可信生产、管理和分发,以及服务网格ASM实现应用无感的零信任安全,确保企业在软件开发和部署过程中的安全性。