Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)

docker 이미지 빌드 시 "RUN apt install ..." 명령어가 실패하는 이유

docker 이미지를 만들 때 apt-get udpate/upgrade도 해놓았는데요,

RUN apt-get update
RUN apt-get upgrade -y

이후 dockerfile의 내용에 sysstat을 설치하는 명령을 추가했더니,

RUN apt install sysstat -y

이렇게 오류가 발생합니다.

c:\temp> docker build -t py38agent-build-machine -f D:\data\build38.dockerfile .
[+] Building 20.5s (20/27)
 => [internal] load build definition from build38.dockerfile                                                                             0.9s
 => => transferring dockerfile: 1.09kB                                                                                                   0.0s
 => [internal] load .dockerignore                                                                                                        1.4s
 => => transferring context: 2B                                                                                                          0.0s
 => resolve image config for docker.io/docker/dockerfile:1                                                                               1.4s
 => CACHED docker-image://docker.io/docker/dockerfile:1@sha256:9ba7531bd80fb0a858632727cf7a112fbfd19b17e94c4e84ced81e24ef1a0dbc          0.0s
 => [internal] load .dockerignore                                                                                                        0.0s
 => [internal] load build definition from build38.dockerfile                                                                             0.0s
 => [internal] load metadata for docker.io/library/python:3.8-slim-buster                                                                0.0s
 => [internal] load metadata for docker.io/library/golang:1.19.0                                                                         2.3s
 => [stage-1  1/17] FROM docker.io/library/python:3.8-slim-buster                                                                        0.0s
 => [internal] load build context                                                                                                        1.0s
 => => transferring context: 55B                                                                                                         0.0s
 => CACHED [go_builder 1/1] FROM docker.io/library/golang:1.19.0@sha256:d3f734e1f46ec36da8c1bce67cd48536138085289e24cfc8765f483c401b7d9  0.0s
 => CACHED [stage-1  2/17] WORKDIR /app                                                                                                  0.0s
 => CACHED [stage-1  3/17] RUN apt-get update                                                                                            0.0s
 => CACHED [stage-1  4/17] RUN apt-get upgrade -y                                                                                        0.0s
 => CACHED [stage-1  5/17] RUN apt-get install libpq-dev -y                                                                              0.0s
 => CACHED [stage-1  6/17] RUN apt install unzip -y                                                                                      0.0s
 => CACHED [stage-1  7/17] RUN python -m pip install --upgrade pip                                                                       0.0s
 => CACHED [stage-1  8/17] RUN apt install git -y                                                                                        0.0s
 => CACHED [stage-1  9/17] RUN apt install curl -y                                                                                       0.0s
 => ERROR [stage-1 10/17] RUN apt install net-tools sysstat nano iputils-ping -y                                                        12.6s
------
 > [stage-1 10/17] RUN apt install net-tools sysstat nano iputils-ping -y:
#18 5.307
#18 5.307 WARNING: apt does not have a stable CLI interface. Use with caution in scripts.
#18 5.307
#18 5.467 Reading package lists...
#18 6.646 Building dependency tree...
#18 6.789 Reading state information...
#18 6.985 The following additional packages will be installed:
#18 6.985   bzip2 cron exim4-base exim4-config exim4-daemon-light file guile-2.2-libs
#18 6.986   libcap2 libcap2-bin libevent-2.1-6 libfribidi0 libgc1c2 libgnutls-dane0
#18 6.986   libgpm2 libgsasl7 libidn11 libkyotocabinet16v5 libltdl7 liblzo2-2
#18 6.987   libmagic-mgc libmagic1 libmailutils5 libmariadb3 libncurses6 libntlm0
#18 6.988   libpam-cap libpython2.7 libpython2.7-minimal libpython2.7-stdlib
#18 6.988   libsensors-config libsensors5 libunbound8 libwrap0 lsb-base mailutils
#18 6.991   mailutils-common mariadb-common mime-support mysql-common psmisc
#18 6.992   sensible-utils ucf xz-utils
#18 6.997 Suggested packages:
#18 6.997   bzip2-doc anacron logrotate checksecurity exim4-doc-html | exim4-doc-info
#18 6.997   eximon4 spf-tools-perl swaks dns-root-data gpm lm-sensors mailutils-mh
#18 6.997   mailutils-doc spell isag
#18 7.733 The following NEW packages will be installed:
#18 7.733   bzip2 cron exim4-base exim4-config exim4-daemon-light file guile-2.2-libs
#18 7.734   iputils-ping libcap2 libcap2-bin libevent-2.1-6 libfribidi0 libgc1c2
#18 7.734   libgnutls-dane0 libgpm2 libgsasl7 libidn11 libkyotocabinet16v5 libltdl7
#18 7.735   liblzo2-2 libmagic-mgc libmagic1 libmailutils5 libmariadb3 libncurses6
#18 7.736   libntlm0 libpam-cap libpython2.7 libpython2.7-minimal libpython2.7-stdlib
#18 7.739   libsensors-config libsensors5 libunbound8 libwrap0 lsb-base mailutils
#18 7.739   mailutils-common mariadb-common mime-support mysql-common nano net-tools
#18 7.739   psmisc sensible-utils sysstat ucf xz-utils
#18 7.906 0 upgraded, 47 newly installed, 0 to remove and 0 not upgraded.
#18 7.906 Need to get 17.8 MB of archives.
#18 7.906 After this operation, 89.4 MB of additional disk space will be used.
#18 7.906 Get:1 http://deb.debian.org/debian buster/main amd64 sensible-utils all 0.0.12 [15.8 kB]
#18 7.906 Get:2 http://security.debian.org/debian-security buster/updates/main amd64 xz-utils amd64 5.2.4-1+deb10u1 [183 kB]
#18 7.929 Get:3 http://deb.debian.org/debian buster/main amd64 lsb-base all 10.2019051400 [28.4 kB]
#18 7.956 Get:4 http://deb.debian.org/debian buster/main amd64 cron amd64 3.0pl1-134+deb10u1 [99.0 kB]
#18 8.024 Get:5 http://deb.debian.org/debian buster/main amd64 libcap2 amd64 1:2.25-2 [17.6 kB]
#18 8.024 Get:6 http://deb.debian.org/debian buster/main amd64 iputils-ping amd64 3:20180629-2+deb10u2 [43.4 kB]
#18 8.025 Get:7 http://deb.debian.org/debian buster/main amd64 nano amd64 3.2-3 [544 kB]
#18 8.108 Get:8 http://deb.debian.org/debian buster/main amd64 bzip2 amd64 1.0.6-9.2~deb10u1 [48.4 kB]
#18 8.112 Get:9 http://deb.debian.org/debian buster/main amd64 libmagic-mgc amd64 1:5.35-4+deb10u2 [242 kB]
#18 8.185 Get:10 http://deb.debian.org/debian buster/main amd64 libmagic1 amd64 1:5.35-4+deb10u2 [118 kB]
#18 8.244 Get:11 http://deb.debian.org/debian buster/main amd64 file amd64 1:5.35-4+deb10u2 [66.4 kB]
#18 8.255 Get:12 http://deb.debian.org/debian buster/main amd64 mime-support all 3.62 [37.2 kB]
#18 8.259 Get:13 http://deb.debian.org/debian buster/main amd64 ucf all 3.0038+nmu1 [69.0 kB]
#18 8.283 Get:14 http://deb.debian.org/debian buster/main amd64 exim4-config all 4.92-8+deb10u6 [324 kB]
#18 8.327 Get:15 http://deb.debian.org/debian buster/main amd64 exim4-base amd64 4.92-8+deb10u6 [1137 kB]
#18 8.536 Get:16 http://deb.debian.org/debian buster/main amd64 libevent-2.1-6 amd64 2.1.8-stable-4 [177 kB]
#18 8.565 Get:17 http://deb.debian.org/debian buster/main amd64 libunbound8 amd64 1.9.0-2+deb10u2 [462 kB]
#18 8.966 Err:18 http://deb.debian.org/debian buster/main amd64 libgnutls-dane0 amd64 3.6.7-4+deb10u7
#18 8.966   404  Not Found [IP: 146.75.50.132 80]
#18 8.966 Get:19 http://deb.debian.org/debian buster/main amd64 exim4-daemon-light amd64 4.92-8+deb10u6 [584 kB]
#18 9.065 Get:20 http://deb.debian.org/debian buster/main amd64 libgc1c2 amd64 1:7.6.4-0.4 [224 kB]
#18 9.117 Get:21 http://deb.debian.org/debian buster/main amd64 libltdl7 amd64 2.4.6-9 [390 kB]
#18 9.156 Get:22 http://deb.debian.org/debian buster/main amd64 libncurses6 amd64 6.1+20181013-2+deb10u2 [102 kB]
#18 9.172 Get:23 http://deb.debian.org/debian buster/main amd64 guile-2.2-libs amd64 2.2.4+1-2+deb10u1 [4968 kB]
#18 9.781 Get:24 http://deb.debian.org/debian buster/main amd64 libcap2-bin amd64 1:2.25-2 [28.8 kB]
#18 10.20 Ign:25 http://deb.debian.org/debian buster/main amd64 libfribidi0 amd64 1.0.5-3.1+deb10u1
#18 10.21 Get:26 http://deb.debian.org/debian buster/main amd64 libgpm2 amd64 1.20.7-5 [35.1 kB]
#18 10.22 Get:27 http://deb.debian.org/debian buster/main amd64 libidn11 amd64 1.33-2.2 [116 kB]
#18 10.24 Get:28 http://deb.debian.org/debian buster/main amd64 libntlm0 amd64 1.5-1+deb10u1 [22.7 kB]
#18 10.25 Get:29 http://deb.debian.org/debian buster/main amd64 libgsasl7 amd64 1.8.0-8+b2 [207 kB]
#18 10.26 Get:25 http://deb.debian.org/debian buster/main amd64 libfribidi0 amd64 1.0.5-3.1+deb10u1 [63.7 kB]
#18 10.31 Get:30 http://deb.debian.org/debian buster/main amd64 liblzo2-2 amd64 2.10-0.1 [56.1 kB]
#18 10.31 Get:31 http://deb.debian.org/debian buster/main amd64 libkyotocabinet16v5 amd64 1.2.76-4.2+b1 [298 kB]
#18 10.34 Get:32 http://deb.debian.org/debian buster/main amd64 mailutils-common all 1:3.5-4 [689 kB]
#18 10.43 Get:33 http://deb.debian.org/debian buster/main amd64 mysql-common all 5.8+1.0.5 [7324 B]
#18 10.44 Get:34 http://deb.debian.org/debian buster/main amd64 mariadb-common all 1:10.3.34-0+deb10u1 [33.0 kB]
#18 10.45 Get:35 http://deb.debian.org/debian buster/main amd64 libmariadb3 amd64 1:10.3.34-0+deb10u1 [173 kB]
#18 10.48 Get:36 http://deb.debian.org/debian buster/main amd64 libpython2.7-minimal amd64 2.7.16-2+deb10u1 [395 kB]
#18 10.51 Get:37 http://deb.debian.org/debian buster/main amd64 libpython2.7-stdlib amd64 2.7.16-2+deb10u1 [1912 kB]
#18 10.75 Get:38 http://deb.debian.org/debian buster/main amd64 libpython2.7 amd64 2.7.16-2+deb10u1 [1036 kB]
#18 10.89 Get:39 http://deb.debian.org/debian buster/main amd64 libmailutils5 amd64 1:3.5-4 [880 kB]
#18 10.99 Get:40 http://deb.debian.org/debian buster/main amd64 libpam-cap amd64 1:2.25-2 [14.3 kB]
#18 10.99 Get:41 http://deb.debian.org/debian buster/main amd64 libsensors-config all 1:3.5.0-3 [31.6 kB]
#18 11.00 Get:42 http://deb.debian.org/debian buster/main amd64 libsensors5 amd64 1:3.5.0-3 [52.6 kB]
#18 11.01 Get:43 http://deb.debian.org/debian buster/main amd64 libwrap0 amd64 7.6.q-28 [58.7 kB]
#18 11.02 Get:44 http://deb.debian.org/debian buster/main amd64 mailutils amd64 1:3.5-4 [585 kB]
#18 11.11 Get:45 http://deb.debian.org/debian buster/main amd64 net-tools amd64 1.60+git20180626.aebd88e-1 [248 kB]
#18 11.15 Get:46 http://deb.debian.org/debian buster/main amd64 psmisc amd64 23.2-1+deb10u1 [126 kB]
#18 11.17 Get:47 http://deb.debian.org/debian buster/main amd64 sysstat amd64 12.0.3-2 [562 kB]
#18 11.22 E: Failed to fetch http://deb.debian.org/debian/pool/main/g/gnutls28/libgnutls-dane0_3.6.7-4+deb10u7_amd64.deb  404  Not Found [IP: 146.75.50.132 80]
#18 11.22 E: Unable to fetch some archives, maybe run apt-get update or try with --fix-missing?
#18 11.22 Fetched 17.5 MB in 3s (5096 kB/s)
------
executor failed running [/bin/sh -c apt install net-tools sysstat nano iputils-ping -y]: exit code: 100

그런데, 위의 메시지를 확인해 보면 재미있는 점이 있습니다. 바로 ""RUN apt-get update/upgrade" 명령어도 다름 아닌 "CACHED" 처리되었다는 점입니다.

...[생략]...
 => CACHED [stage-1  2/17] WORKDIR /app                                                                                                  0.0s
 => CACHED [stage-1  3/17] RUN apt-get update                                                                                            0.0s
 => CACHED [stage-1  4/17] RUN apt-get upgrade -y                                                                                        0.0s
 => CACHED [stage-1  5/17] RUN apt-get install libpq-dev -y                                                                              0.0s
...[생략]...

따라서 cache를 이용하지 않도록 만들어야 하는데요, 이를 위해 "--no-cache" 옵션을 (실패할 때마다 한 번씩만) 추가하면 됩니다.

c:\temp> docker build --no-cache=true -t py38agent-build-machine -f D:\data\build38.dockerfile .
[+] Building 36.4s (13/27)
 => [internal] load build definition from build38.dockerfile                                                                             2.1s
 => => transferring dockerfile: 1.09kB                                                                                                   0.0s
 => [internal] load .dockerignore                                                                                                        1.4s
 => => transferring context: 2B                                                                                                          0.0s
 => resolve image config for docker.io/docker/dockerfile:1                                                                               1.3s
 => CACHED docker-image://docker.io/docker/dockerfile:1@sha256:9ba7531bd80fb0a858632727cf7a112fbfd19b17e94c4e84ced81e24ef1a0dbc          0.0s
 => [internal] load build definition from build38.dockerfile                                                                             0.0s
 => [internal] load .dockerignore                                                                                                        0.0s
 => [internal] load metadata for docker.io/library/golang:1.19.0                                                                         1.3s
 => [internal] load metadata for docker.io/library/python:3.8-slim-buster                                                                0.0s
 => [stage-1  1/17] FROM docker.io/library/python:3.8-slim-buster                                                                        0.0s
 => [internal] load build context                                                                                                        1.0s
 => => transferring context: 55B                                                                                                         0.0s
 => CACHED [go_builder 1/1] FROM docker.io/library/golang:1.19.0@sha256:d3f734e1f46ec36da8c1bce67cd48536138085289e24cfc8765f483c401b7d9  0.1s
 => CACHED [stage-1  2/17] WORKDIR /app                                                                                                  0.0s
 => [stage-1  3/17] RUN apt-get update                                                                                                   8.0s
 => [stage-1  4/17] RUN apt-get upgrade -y                                                                                              20.6s
 => => # Setting up base-files (10.3+deb10u13) ...
 => => # Installing new version of config file /etc/debian_version ...
 => => # (Reading database ... 6840 files and directories currently installed.)
 => => # Preparing to unpack .../archives/dpkg_1.19.8_amd64.deb ...
 => => # Unpacking dpkg (1.19.8) over (1.19.7) ...
 => => # Setting up dpkg (1.19.8) ...




이 현상 덕분에 지난번에 겪었던 그 글의 원인이 밝혀집니다. ^^;

Linux - apt와 apt-get의 차이
; https://www.sysnet.pe.kr/2/0/13075

그러니까, 그때 당시에 "RUN apt update/upgrade"는 CACHED 처리되었기 때문에 "apt install libpq-dev" 명령어가 실패했던 것입니다. 하지만, 명령어를 apt-get으로 바꾸면 CACHED가 아닌, 새롭게 이미지를 재구성했기 때문에 정상적으로 이미지 빌드가 되었던 것이고!




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 1/9/2023]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 136  137  138  139  140  141  142  143  144  145  146  147  148  149  [150]  ...
NoWriterDateCnt.TitleFile(s)
1303정성태6/26/201227397개발 환경 구성: 152. sysnet DB를 SQL Azure 데이터베이스로 마이그레이션
1302정성태6/25/201229404개발 환경 구성: 151. Azure 웹 사이트에 사용자 도메인 네임 연결하는 방법
1301정성태6/20/201225763오류 유형: 156. KB2667402 윈도우 업데이트 실패 및 마이크로소프트 Answers 웹 사이트 대응
1300정성태6/20/201231767.NET Framework: 329. C# - Rabin-Miller 소수 생성방법을 이용하여 RSACryptoServiceProvider의 개인키를 직접 채워보자 [1]파일 다운로드2
1299정성태6/18/201232880제니퍼 .NET: 21. 제니퍼 닷넷 - Ninject DI 프레임워크의 성능 분석 [2]파일 다운로드2
1298정성태6/14/201234405VS.NET IDE: 72. Visual Studio에서 pfx 파일로 서명한 경우, 암호는 어디에 저장될까? [2]
1297정성태6/12/201231048VC++: 63. 다른 프로세스에 환경 변수 설정하는 방법파일 다운로드1
1296정성태6/5/201227675.NET Framework: 328. 해당 DLL이 Managed인지 / Unmanaged인지 확인하는 방법 - 두 번째 이야기 [4]파일 다운로드1
1295정성태6/5/201225077.NET Framework: 327. RSAParameters와 System.Numerics.BigInteger 이야기파일 다운로드1
1294정성태5/27/201248524.NET Framework: 326. 유니코드와 한글 - 유니코드와 닷넷을 이용한 한글 처리 [7]파일 다운로드2
1293정성태5/24/201229773.NET Framework: 325. System.Drawing.Bitmap 데이터를 Parallel.For로 처리하는 방법 [2]파일 다운로드1
1292정성태5/24/201223754.NET Framework: 324. First-chance exception에 대해 조건에 따라 디버거가 멈추게 할 수는 없을까? [1]파일 다운로드1
1291정성태5/23/201230274VC++: 62. 배열 초기화를 위한 기계어 코드 확인 [2]
1290정성태5/18/201235078.NET Framework: 323. 관리자 권한이 필요한 작업을 COM+에 대행 [7]파일 다운로드1
1289정성태5/17/201239237.NET Framework: 322. regsvcs.exe로 어셈블리 등록 시 시스템 변경 사항 [5]파일 다운로드2
1288정성태5/17/201226461.NET Framework: 321. regasm.exe로 어셈블리 등록 시 시스템 변경 사항 (3) - Type Library파일 다운로드1
1287정성태5/17/201229297.NET Framework: 320. regasm.exe로 어셈블리 등록 시 시스템 변경 사항 (2) - .NET 4.0 + .NET 2.0 [2]
1286정성태5/17/201238217.NET Framework: 319. regasm.exe로 어셈블리 등록 시 시스템 변경 사항 (1) - .NET 2.0 + x86/x64/AnyCPU [5]
1285정성태5/16/201233264.NET Framework: 318. gacutil.exe로 어셈블리 등록 시 시스템 변경 사항파일 다운로드1
1284정성태5/15/201225692오류 유형: 155. Windows Phone 연결 상태에서 DRIVER POWER STATE FAILURE 블루 스크린 뜨는 현상
1283정성태5/12/201233307.NET Framework: 317. C# 관점에서의 Observer 패턴 구현 [1]파일 다운로드1
1282정성태5/12/201226105Phone: 6. Windows Phone 7 Silverlight에서 Google Map 사용하는 방법 [3]파일 다운로드1
1281정성태5/9/201233187.NET Framework: 316. WPF/Silverlight의 그래픽 단위와 Anti-aliasing 처리를 이해하자 [1]파일 다운로드1
1280정성태5/9/201226154오류 유형: 154. Could not load type 'System.ServiceModel.Activation.HttpModule' from assembly 'System.ServiceModel, ...'.
1279정성태5/9/201224917.NET Framework: 315. 해당 DLL이 Managed인지 / Unmanaged인지 확인하는 방법 [1]파일 다운로드1
1278정성태5/8/201226145오류 유형: 153. Visual Studio 디버깅 - Unable to break execution. This process is not currently executing the type of code that you selected to debug.
... 136  137  138  139  140  141  142  143  144  145  146  147  148  149  [150]  ...