Chupurnov Valeriy
Chupurnov Valeriy
Front End Engineer

docker build не показывает никаких выходных данных из команд (RUN в Dockerfile)

Описание проблемы

Вот содержимое Dockerfile:

FROM alpine

ADD . /app/
WORKDIR /app
RUN echo "hello world"
RUN ls -l

При использовании Docker для выполнения сборки я обнаружил, что команда RUN не показывает результат работы.

Иногда при отладке требуется вывести содержимое директории или переменной.

❯ docker build -t test -f Dockerfile .
[+] Building 1.0s (10/10) FINISHED
 => [internal] load build definition from Dockerfile                                                                                                                        0.0s
 => => transferring dockerfile: 112B                                                                                                                                        0.0s
 => [internal] load .dockerignore                                                                                                                                           0.0s
 => => transferring context: 2B                                                                                                                                             0.0s
 => [internal] load metadata for docker.io/library/alpine:latest                                                                                                            0.0s
 => [internal] load build context                                                                                                                                           0.0s
 => => transferring context: 107B                                                                                                                                           0.0s
 => CACHED [1/5] FROM docker.io/library/alpine                                                                                                                              0.0s
 => [2/5] ADD . /app/                                                                                                                                                       0.0s
 => [3/5] WORKDIR /app                                                                                                                                                      0.0s
 => [4/5] RUN echo "hello world"                                                                                                                                            0.4s
 => [5/5] RUN ls -l                                                                                                                                                         0.4s
 => exporting to image                                                                                                                                                      0.1s
 => => exporting layers                                                                                                                                                     0.0s
 => => writing image sha256:123                                                                               0.0s
 => => naming to docker.io/library/test

Это очень неудобно именно для отладки при создании образов.

Решение

Добавьте DOCKER_BUILDKIT=0 перед командой docker build, чтобы отображать результат работы команды.

❯ DOCKER_BUILDKIT=0 docker build -t test -f Dockerfile .

Sending build context to Docker daemon  2.048kB
Step 1/5 : FROM alpine
 ---> 183faf728851
Step 2/5 : ADD . /app/
 ---> 34cccaf2b826
Step 3/5 : WORKDIR /app
 ---> Running in 11eefb594656
Removing intermediate container 11eefb594656
 ---> 07582a62e423
Step 4/5 : RUN echo "hello world"
 ---> Running in dcc093d3310
hello world
Removing intermediate container bcd94b080379
 ---> 6fbc11007cff
Step 5/5 : RUN ls -l
 ---> Running in 8d9423839270
total 4
-rw-r--r--    1 root     root            70 Apr 29 03:07 Dockerfile
Removing intermediate container 8d9423839270
 ---> 7b6aee767fab
Successfully built 7b6aee767fab
Successfully tagged test:latest

Ссылка

https://stackoverflow.com/questions/64804749/docker-build-not-showing-any-output-from-commands