성태의 닷넷 이야기
홈 주인
모아 놓은 자료
프로그래밍
질문/답변
사용자 관리
사용자
메뉴
아티클
외부 아티클
유용한 코드
온라인 기능
MathJax 입력기
최근 덧글
[정성태] 그냥 RSS Reader 기능과 약간의 UI 편의성 때문에 사용...
[이종효] 오래된 소프트웨어는 보안 위협이 되기도 합니다. 혹시 어떤 기능...
[정성태] @Keystroke IEEE의 문서를 소개해 주시다니... +_...
[손민수 (Keystroke)] 괜히 듀얼채널 구성할 때 한번에 같은 제품 사라고 하는 것이 아...
[정성태] 전각(Full-width)/반각(Half-width) 기능을 토...
[정성태] Vector에 대한 내용은 없습니다. Vector가 닷넷 BCL...
[orion] 글 읽고 찾아보니 디자인 타임에는 InitializeCompon...
[orion] 연휴 전에 재현 프로젝트 올리자 생각해 놓고 여의치 않아서 못 ...
[정성태] 아래의 글에 정리했으니 참고하세요. C# - Typed D...
[정성태] 간단한 재현 프로젝트라도 있을까요? 저런 식으로 설명만 해...
글쓰기
제목
이름
암호
전자우편
HTML
홈페이지
유형
제니퍼 .NET
닷넷
COM 개체 관련
스크립트
VC++
VS.NET IDE
Windows
Team Foundation Server
디버깅 기술
오류 유형
개발 환경 구성
웹
기타
Linux
Java
DDK
Math
Phone
Graphics
사물인터넷
부모글 보이기/감추기
내용
<div style='display: inline'> <h1 style='font-family: Malgun Gothic, Consolas; font-size: 20pt; color: #006699; text-align: center; font-weight: bold'>docker 이미지 빌드 시 "RUN apt install ..." 명령어가 실패하는 이유</h1> <p> docker 이미지를 만들 때 apt-get udpate/upgrade도 해놓았는데요,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > RUN apt-get update RUN apt-get upgrade -y </pre> <br /> 이후 dockerfile의 내용에 sysstat을 설치하는 명령을 추가했더니,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > RUN apt install sysstat -y </pre> <br /> 이렇게 오류가 발생합니다.<br /> <br /> <pre style='height: 500px; margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > c:\temp> <span style='color: blue; font-weight: bold'>docker build -t py38agent-build-machine -f D:\data\build38.dockerfile .</span> [+] 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 </pre> <br /> 그런데, 위의 메시지를 확인해 보면 재미있는 점이 있습니다. 바로 ""RUN apt-get update/upgrade" 명령어도 다름 아닌 "CACHED" 처리되었다는 점입니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > ...[생략]... => 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 ...[생략]... </pre> <br /> 따라서 cache를 이용하지 않도록 만들어야 하는데요, 이를 위해 "--no-cache" 옵션을 (실패할 때마다 한 번씩만) 추가하면 됩니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > c:\temp> docker build <span style='color: blue; font-weight: bold'>--no-cache=true</span> -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) ... </pre> <br /> <hr style='width: 50%' /><br /> <br /> 이 현상 덕분에 지난번에 겪었던 그 글의 원인이 밝혀집니다. ^^;<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > Linux - apt와 apt-get의 차이 ; <a target='tab' href='https://www.sysnet.pe.kr/2/0/13075'>https://www.sysnet.pe.kr/2/0/13075</a> </pre> <br /> 그러니까, 그때 당시에 "RUN apt update/upgrade"는 CACHED 처리되었기 때문에 "apt install libpq-dev" 명령어가 실패했던 것입니다. 하지만, 명령어를 apt-get으로 바꾸면 CACHED가 아닌, 새롭게 이미지를 재구성했기 때문에 정상적으로 이미지 빌드가 되었던 것이고!<br /> </p><br /> <br /><hr /><span style='color: Maroon'>[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]</span> </div>
첨부파일
스팸 방지용 인증 번호
1627
(왼쪽의 숫자를 입력해야 합니다.)