前言
在当今的软件开发和运维领域,容器化技术已经成为了一种趋势。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