Dockerfile 中 ARG 的使用与其作用域(Scope)探究

运维
使用 ARG​ 可以有效的复用 Dockerfile。每次镜像更新,只需要动态的在 build 命令中传入新的参数值即可。

使用 ARG​ 可以有效的复用 Dockerfile。每次镜像更新,只需要动态的在 build 命令中传入新的参数值即可。

0x01 结论

  • 在第一个FROM​ 之前的所有 ARG , 在所有 FROM​ 中生效, 仅在 FROM 中生效
  • 在FROM​ 后的 ARG​, 仅在当前 FROM 作用域生效。即尽在当前 阶段 (stage)

对照组解析

在随后的 Dockerfile 中, 只定义了一个变量 image​ , 并在 FROM 和 stage

  • 对照组1:stage1​ 和 stage11​ 均在 FROM​ 中使用了变量 $image​: **作用域在所有 FROM 中

成功拉取FROM $image 并完成 layer 构建

但是在RUN 中无法正确输出结果,即 image 的值 alpine:3.12

  • 对照组2:stage1​ vs stage2: 作用域在 FROM stage 内部

在 stage2​ 的作用域中声明了 ARG image,且能正确输出结果。

  • 对照组3: stage2​ vs stage21​: 作用域仅在当前 FROM stage 内部

虽然 stage2​ 在 stage21​ 上方且声明了 ARG image​, 但 stage21 仍然不能不能正确输出结果。

0x02 实验过程

创建 Dockerfile 如下:


## 在第一个 FROM 之前的所有 ARG , 在所有 FROM 中生效, 仅在 FROM 中生效
ARG image

FROM $image as stage1
RUN echo "stage1 -> base from image is : $image "
# result: stage1 -> base from image is :

FROM $image as stage11
RUN echo "stage11 -> base from image is : $image "
# result: stage11 -> base from image is :

FROM alpine:3.12 as stage2
## 在 FROM 后的 ARG, 仅在当前 FROM 作用域生效。即尽在当前 阶段 (stage) 生效
ARG image
RUN echo "stage2 -> base from image is : $image "
# stage2 -> base from image is : alpine:3.12

FROM alpine:3.12 as stage21
RUN echo "stage21 -> base from image is : $image "
# stage21 -> base from image is :

执行docker build 命令:

# docker build --build-arg image=alpine:3.12 --no-cache .

build 结果展示:

Sending build context to Docker daemon  3.072kB
Step 1/10 : ARG image
Step 2/10 : FROM $image as stage1
---> d6e46aa2470d
Step 3/10 : RUN echo "stage1 -> base from image is : $image "
---> Running in ecb7be5dd9cc
stage1 -> base from image is : ### image 结果未输出
Removing intermediate container ecb7be5dd9cc
---> 04807c8d53be
Step 4/10 : FROM $image as stage11
---> d6e46aa2470d
Step 5/10 : RUN echo "stage11 -> base from image is : $image "
---> Running in a90e45076345
stage11 -> base from image is : ### image 结果未输出
Removing intermediate container a90e45076345
---> f2dbce837a1b
Step 6/10 : FROM alpine:3.12 as stage2
---> d6e46aa2470d
Step 7/10 : ARG image
---> Running in 5c8cec4c2f22
Removing intermediate container 5c8cec4c2f22
---> 999d9990bd91
Step 8/10 : RUN echo "stage2 -> base from image is : $image "
---> Running in 4407dcb0e0bb
stage2 -> base from image is : alpine:3.12 ### image 结果输出
Removing intermediate container 4407dcb0e0bb
---> e5ddd7a84f81
Step 9/10 : FROM alpine:3.12 as stage21
---> d6e46aa2470d
Step 10/10 : RUN echo "stage21 -> base from image is : $image "
---> Running in 64a0a3bb090c
stage21 -> base from image is : ### image 结果未输出
Removing intermediate container 64a0a3bb090c
---> 82665f9a1037
Successfully built 82665f9a1037

0x03 参考文档

  • set-build-time-variables—build-arg

0x04 to be continue

在以后的时间, 笔者将继续讨论 ARG 在 docker buildx 多节构建时的影响和使用。

责任编辑:武晓燕 来源: 高薪运维
相关推荐

2023-09-05 08:23:56

SpringScope方法

2021-07-05 08:43:46

Spring Beanscope作用域

2024-01-05 08:38:20

SpringBeanScope

2011-03-18 09:27:00

Spring

2020-05-25 17:03:47

Vue嵌套插槽开发

2021-06-02 07:02:42

js作用域函数

2011-05-12 18:26:08

Javascript作用域

2021-04-14 07:52:00

Vue 作用域插槽

2009-06-12 09:49:25

EJB事务属性EJB事物

2009-06-01 11:16:48

PHP网站开发变量作用域

2010-03-19 13:17:26

Parallel

2010-09-29 15:02:23

DHCP作用域

2011-09-06 09:56:24

JavaScript

2021-03-17 08:39:24

作用域作用域链JavaScript

2010-08-25 14:11:01

CSSborder-top

2021-03-09 08:35:51

JSS作用域前端

2019-03-13 08:00:00

JavaScript作用域前端

2020-08-25 10:02:09

AndroidHilt作用域

2020-03-24 08:32:24

vue作用域前端

2021-03-16 22:25:06

作用域链作用域JavaScript
点赞
收藏

51CTO技术栈公众号