从本质上讲,docker镜像确实只是一个tar文件,这个tar文件里面可能又包含其他tar文件。docker镜像实际上由多个层组成,每个层都是一个tar文件。这些层包含镜像的不同部分,例如应用程序代码、依赖项和系统库。
当创建docker镜像时,这些层被堆叠在一起,每个层代表镜像的一个更改。例如,一个层可能包含基本操作系统,而另一个层可能包含应用程序代码和任何必要的依赖项。
当从镜像创建Docker容器时,这些层被提取并组合在一起,为容器创建一个单独的文件系统。这使得容器可以拥有自己的隔离环境,而不会干扰主机系统。
下面我们来构建一个Docker镜像实验看看,先看一下镜像的Dockerfile
Dockerfile:
FROM ubuntu:focal
COPY sources.list /etc/apt/sources.list
RUN apt-get update
RUN apt-get -y install python3 python3-pip
RUN pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple ansible
COPY用到的 sources.list(用来加速apt install):
deb http://mirrors.aliyun.com/ubuntu/ focal main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ focal main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ focal-security main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ focal-security main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ focal-updates main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ focal-updates main restricted universe multiverse
# deb http://mirrors.aliyun.com/ubuntu/ focal-proposed main restricted universe multiverse
# deb-src http://mirrors.aliyun.com/ubuntu/ focal-proposed main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ focal-backports main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ focal-backports main restricted universe multiverse
当前目录文件:
使用docker命令构建
docker build -t ansible .
由于之前构建过了,就不再重新构建了,我们用命令看一下镜像
docker images # 或者 docker image ls
导出ansible这个镜像:
docker save ansible -o ansible.tar
用tar命令查看ansible.tar包文件列表:
tar tf ansible.tar
从上面的实验我们可以知道,本质上docker镜像就是一个tar文件
页面更新:2024-05-12
本站资料均由网友自行发布提供,仅用于学习交流。如有版权问题,请与我联系,QQ:4156828
© CopyRight 2020-2024 All Rights Reserved. Powered By 71396.com 闽ICP备11008920号-4
闽公网安备35020302034903号