docker镜像构建分析

docker镜像分析工具dive

查看docker的构建过程.
项目地址: https://github.com/wagoodman/dive/releases/

# 下载dive
curl -OL https://github.com/wagoodman/dive/releases/download/v0.9.2/dive_0.9.2_linux_amd64.rpm

# 安装dive
rpm -i dive_0.9.2_linux_amd64.rpm

# yum一步安装
yum install -y https://github.com/wagoodman/dive/releases/download/v0.9.2/dive_0.9.2_linux_amd64.rpm

分析镜像

# dive 镜像名:tag名
dive <your-image-tag>

在这里插入图片描述


dive分析镜像构建

使用dive分析dockerfile构建过程

# cd到项目根目录
cd 项目目录

# -f 指定dockerfile
dive build -t 镜像名:标签 .

# dive build -t
## -t 指定镜像名:tag
dive build -t <some-tag> -f .

在这里插入图片描述
在这里插入图片描述


查看镜像的构建步骤

# 查看构建镜像经过了哪些步骤
docker history 镜像名

docker history显示不全

查看完整镜像构建过程

# 查看完整构建过程,显示很不友好
## --no-trunc : 禁止截断输出内容(显示完整的命令和层信息)
docker history 镜像名 --no-trunc

# 自定义友好显示
docker history 镜像名:tag --format "table {{.ID}}\t{{.CreatedBy}}" --no-trunc 

结果是从下往上
在这里插入图片描述


使用whaler查看容器构建过程

项目地址: https://github.com/P3GLEG/Whaler


安装whaler

# 安装whaler到/usr/local/bin/目录下
wget -cO /usr/local/bin/whaler https://github.com/P3GLEG/Whaler/releases/download/1.0/Whaler_linux_amd64

# 赋予可执行权限
chmod +x /usr/local/bin/whaler

whaler常用参数

# 将docker客户端ID设置为特定版本-sV
whaler -sV=1.36 

# 打印有关图像的所有详细信息 -v 
whaler -v 镜像名

在这里插入图片描述

# 将镜像层保存到当前目录-x
whaler -x 镜像名

将镜像逆向为dockfile

逆向镜像为dockfile

# 逆向镜像
whaler 镜像名

在这里插入图片描述

# 示例
[master root ~]# whaler nginx
Analyzing nginx
Docker Version: 20.10.7
GraphDriver: overlay2
Environment Variables
|PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
|NGINX_VERSION=1.21.5
|NJS_VERSION=0.7.1
|PKG_RELEASE=1~bullseye

Open Ports
|80

Image user
|User is root

Potential secrets:
Dockerfile:
CMD ["bash"]
LABEL maintainer=NGINX Docker Maintainers <docker-maint@nginx.com>
ENV NGINX_VERSION=1.21.5
ENV NJS_VERSION=0.7.1
ENV PKG_RELEASE=1~bullseye
RUN set -x  \
        && addgroup --system --gid 101 nginx  \
        && adduser --system --disabled-login --ingroup nginx --no-create-home --home /nonexistent --gecos "nginx user" --shell /bin/false --uid 101 nginx  \
        && apt-get update  \
        && apt-get install --no-install-recommends --no-install-suggests -y gnupg1 ca-certificates  \
        && NGINX_GPGKEY=573BFD6B3D8FBC641079A6ABABF5BD827BD9BF62; found=''; for server in hkp://keyserver.ubuntu.com:80 pgp.mit.edu ; do echo "Fetching GPG key $NGINX_GPGKEY from $server"; apt-key adv --keyserver "$server" --keyserver-options timeout=10 --recv-keys "$NGINX_GPGKEY"  \
        && found=yes  \
        && break; done; test -z "$found"  \
        && echo >&2 "error: failed to fetch GPG key $NGINX_GPGKEY"  \
        && exit 1; apt-get remove --purge --auto-remove -y gnupg1  \
        && rm -rf /var/lib/apt/lists/*  \
        && dpkgArch="$(dpkg --print-architecture)"  \
        && nginxPackages=" nginx=${NGINX_VERSION}-${PKG_RELEASE} nginx-module-xslt=${NGINX_VERSION}-${PKG_RELEASE} nginx-module-geoip=${NGINX_VERSION}-${PKG_RELEASE} nginx-module-image-filter=${NGINX_VERSION}-${PKG_RELEASE} nginx-module-njs=${NGINX_VERSION}+${NJS_VERSION}-${PKG_RELEASE} "  \
        && case "$dpkgArch" in amd64|arm64) echo "deb https://nginx.org/packages/mainline/debian/ bullseye nginx" >> /etc/apt/sources.list.d/nginx.list  \
        && apt-get update ;; *) echo "deb-src https://nginx.org/packages/mainline/debian/ bullseye nginx" >> /etc/apt/sources.list.d/nginx.list  \
        && tempDir="$(mktemp -d)"  \
        && chmod 777 "$tempDir"  \
        && savedAptMark="$(apt-mark showmanual)"  \
        && apt-get update  \
        && apt-get build-dep -y $nginxPackages  \
        && ( cd "$tempDir"  \
        && DEB_BUILD_OPTIONS="nocheck parallel=$(nproc)" apt-get source --compile $nginxPackages )  \
        && apt-mark showmanual | xargs apt-mark auto > /dev/null  \
        && { [ -z "$savedAptMark" ] || apt-mark manual $savedAptMark; }  \
        && ls -lAFh "$tempDir"  \
        && ( cd "$tempDir"  \
        && dpkg-scanpackages . > Packages )  \
        && grep '^Package: ' "$tempDir/Packages"  \
        && echo "deb [ trusted=yes ] file://$tempDir ./" > /etc/apt/sources.list.d/temp.list  \
        && apt-get -o Acquire::GzipIndexes=false update ;; esac  \
        && apt-get install --no-install-recommends --no-install-suggests -y $nginxPackages gettext-base curl  \
        && apt-get remove --purge --auto-remove -y  \
        && rm -rf /var/lib/apt/lists/* /etc/apt/sources.list.d/nginx.list  \
        && if [ -n "$tempDir" ]; then apt-get purge -y --auto-remove  \
        && rm -rf "$tempDir" /etc/apt/sources.list.d/temp.list; fi  \
        && ln -sf /dev/stdout /var/log/nginx/access.log  \
        && ln -sf /dev/stderr /var/log/nginx/error.log  \
        && mkdir /docker-entrypoint.d
COPY file:65504f71f5855ca017fb64d502ce873a31b2e0decd75297a8fb0a287f97acf92 in /
        docker-entrypoint.sh

COPY file:0b866ff3fc1ef5b03c4e6c8c513ae014f691fb05d530257dfffd07035c1b75da in /docker-entrypoint.d
        docker-entrypoint.d/
        docker-entrypoint.d/10-listen-on-ipv6-by-default.sh

COPY file:0fd5fca330dcd6a7de297435e32af634f29f7132ed0550d342cad9fd20158258 in /docker-entrypoint.d
        docker-entrypoint.d/
        docker-entrypoint.d/20-envsubst-on-templates.sh

COPY file:09a214a3e07c919af2fb2d7c749ccbc446b8c10eb217366e5a65640ee9edcc25 in /docker-entrypoint.d
        docker-entrypoint.d/
        docker-entrypoint.d/30-tune-worker-processes.sh

ENTRYPOINT ["/docker-entrypoint.sh"]
EXPOSE 80
STOPSIGNAL SIGQUIT
CMD ["nginx" "-g" "daemon off;"]
### 如何构建 Docker 镜像 #### 使用 `docker build` 命令构建镜像 Docker 提供了 `docker build` 命令,该命令允许开发人员将应用程序转换为可在任何地方运行的可移植容器[^1]。此过程涉及编写一个名为 Dockerfile 的文本文件,其中包含一系列指令用于组装镜像。 #### 编写 Dockerfile Dockerfile 是一种简单的配置文件,由一组特定格式化的指令组成。下面是一个基本的例子: ```dockerfile FROM openjdk:8-jdk-alpine WORKDIR /app COPY . . RUN javac App.java CMD ["java", "App"] ``` 这段代码指定了基础镜像 (`openjdk`) 并设置了工作目录 `/app` ,接着复制当前上下文中的所有文件到这个新位置并编译 Java 文件最后指定启动容器时执行的默认命令。 对于更复杂的项目,比如基于 Spring Boot 应用程序,在版本 2.3.x 中引入了一种优化过的多阶段构建方法来加速构建流程、减少最终镜像大小以及提高安全性[^2]。这种技术通过分离不同阶段的任务(如编译源码与打包应用),从而只保留必要的部分进入生产环境使用的精简版镜像中。 #### 执行构建操作 准备好上述提到的 Dockerfile 后就可以调用 `docker build` 来创建一个新的镜像实例: ```bash $ docker build -t my-app-image:v1 . ``` 这里的 `-t` 参数用来给即将生成的新镜像打标签(`my-app-image:v1`);而后面的`.`表示当前路径作为构建上下文(context),即告诉 Docker 客户端在哪里查找所需的资源以完成整个构建过程。 一旦成功完成了这一步骤之后便可以通过如下方式查看本地存储的所有可用镜像列表: ```bash $ docker images ls ``` #### 推送至私有仓库 当需要分享所制作好的镜像给别人或是部署到远程服务器上去的时候就需要先注册登录对应的私有 Registry : ```bash $ docker login gitlab.example.com:5555 ``` 然后标记(tagging)好准备上传的目标镜像以便于识别其归属关系: ```bash $ docker tag my-app-image:v1 gitlab.example.com/group/my-app-repo:latest ``` 最后再将其推送到目标地址即可实现共享目的: ```bash $ docker push gitlab.example.com/group/my-app-repo:latest ``` 以上就是关于如何使用 Docker 构建镜像的一个简单介绍[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

教Linux的李老师

赞赏是第一生产力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值