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

Docker Desktop에서 별도 서버에 설치한 docker registry에 이미지 올리는 방법

우선, 자신의 docker에 등록된 이미지를 확인하고,

C:\temp> docker images
REPOSITORY                TAG               IMAGE ID       CREATED       SIZE
build_test                latest            26d17c08ce0c   4 weeks ago   377MB
py38agent-build-machine   latest            3940b80cf93a   4 weeks ago   680MB
golang                    latest            37eabbc422cd   5 weeks ago   941MB
myapp_uwsgi               latest            ab2031a9d876   5 weeks ago   220MB
python                    3.8-slim-buster   d78a351dcf4a   6 weeks ago   114MB

이들을 대상으로 원격에 올릴 수 있습니다. 이 글에서는 "py38agent-build-machine"을 192.168.100.5:5000에 서비스 중인 docker registry에 올린다고 가정해 보겠습니다.

이를 위해 우선 원격 docker 레지스트리에 대한 HTTP 접점을 이미지에 태깅해야 합니다.

C:\temp> docker tag py38agent-build-machine 192.168.100.5:5000/py38agent-build-machine

C:\temp> docker images
REPOSITORY                                 TAG               IMAGE ID       CREATED       SIZE
build_test                                 latest            26d17c08ce0c   4 weeks ago   377MB
192.168.100.5:5000/py38agent-build-machine   latest            3940b80cf93a   4 weeks ago   680MB
py38agent-build-machine                    latest            3940b80cf93a   4 weeks ago   680MB
golang                                     latest            37eabbc422cd   5 weeks ago   941MB
myapp_uwsgi                                latest            ab2031a9d876   5 weeks ago   220MB
python                                     3.8-slim-buster   d78a351dcf4a   6 weeks ago   114MB

보는 바와 같이 "py38agent-build-machine" 항목과 "IMAGE ID"가 정확히 같은, 하지만 이름만 다른 "192.168.100.5:5000/py38agent-build-machine" 항목이 생겼습니다.

이쯤에서, 사실 개인적으로 왜 이런 태깅 단계를 두었는지 이해가 안 됩니다. 굳이 저렇게 하지 않아도 원격 registry에 올릴 수 있도록 docker 실행 파일에 옵션을 구성하면 될 텐데... 어째서 저렇게 중복 항목을 생성해 목록을 어지럽히는 결과를 감수했던 것일까요? (혹시 이에 대한 이력을 아시는 분은 덧글 부탁드립니다. ^^)

암튼, 저렇게 태깅 정보에 "192.168.100.5:5000"이라는 원격 docker registry에 대한 정보를 포함하고 있어서 해당 이미지를 push 하는 작업은 다음과 같이 간단하게 이뤄집니다.

C:\temp> docker push 192.168.100.5:5000/py38agent-build-machine
Using default tag: latest
The push refers to repository [192.168.100.5:5000/py38agent-build-machine]
Get "https://192.168.100.5:5000/v2/": http: server gave HTTP response to HTTPS client

명령은 저렇게 간단한데, 오류가 발생했군요. 이것은, 해당 docker registry 서버에서 https 통신을 제공하지 않기 때문입니다. 따라서, docker registry 측이 https 통신을 열어주거나, 아니면 클라이언트 측에서 HTTP 통신도 괜찮다는 것을 알려주면 됩니다.

여기서는 후자의 방법을 살펴보는데, 이를 위해 docker desktop에 다음과 같은 설정을 추가합니다

docker_registry_with_ddw_1.png

{
  "builder": {
    "gc": {
      "defaultKeepStorage": "20GB",
      "enabled": true
    }
  },
  "experimental": false,
  "features": {
    "buildkit": true
  },
  "insecure-registries": ["192.168.100.5:5000"]
}

참고로, 이 설정 값은 "%USERPROFILE%\.docker\daemon.json" 경로에 저장이 됩니다. 이후, 재차 "docker tag py38agent-build-machine 192.168.100.5:5000/py38agent-build-machine" 명령어를 수행하면 정상적으로 실행되는 것을 확인할 수 있습니다.

C:\temp> docker push 192.168.100.5:5000/py38agent-build-machine
Using default tag: latest
The push refers to repository [192.168.100.5:5000/py38agent-build-machine]
98819e3ca6f1: Pushed
...[생략]...
f11bbd657c82: Pushed
latest: digest: sha256:78190d5c444209986c59e42fe73b6792ec4d6644369c2db5e190aced00beb789 size: 4091




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 11/13/2023]

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

비밀번호

댓글 작성자
 




... 31  32  33  34  35  36  37  38  39  40  41  42  43  [44]  45  ...
NoWriterDateCnt.TitleFile(s)
12544정성태2/26/202111671.NET Framework: 1025. C# - Control의 Invalidate, Update, Refresh 차이점 [2]
12543정성태2/26/202110010VS.NET IDE: 158. C# - 디자인 타임(design-time)과 런타임(runtime)의 코드 실행 구분
12542정성태2/20/202112342개발 환경 구성: 544. github repo의 Release 활성화 및 Actions를 이용한 자동화 방법 [1]
12541정성태2/18/20219575개발 환경 구성: 543. 애저듣보잡 - Github Workflow/Actions 소개
12540정성태2/17/20219898.NET Framework: 1024. C# - Win32 API에 대한 P/Invoke를 대신하는 Microsoft.Windows.CsWin32 패키지
12539정성태2/16/20219806Windows: 189. WM_TIMER의 동작 방식 개요파일 다운로드1
12538정성태2/15/202110208.NET Framework: 1023. C# - GC 힙이 아닌 Native 힙에 인스턴스 생성 - 0SuperComicLib.LowLevel 라이브러리 소개 [2]
12537정성태2/11/202111266.NET Framework: 1022. UI 요소의 접근은 반드시 그 UI를 만든 스레드에서! - 두 번째 이야기 [2]
12536정성태2/9/202110214개발 환경 구성: 542. BDP(Bandwidth-delay product)와 TCP Receive Window
12535정성태2/9/20219369개발 환경 구성: 541. Wireshark로 확인하는 LSO(Large Send Offload), RSC(Receive Segment Coalescing) 옵션
12534정성태2/8/20219877개발 환경 구성: 540. Wireshark + C/C++로 확인하는 TCP 연결에서의 closesocket 동작 [1]파일 다운로드1
12533정성태2/8/20219591개발 환경 구성: 539. Wireshark + C/C++로 확인하는 TCP 연결에서의 shutdown 동작파일 다운로드1
12532정성태2/6/202110089개발 환경 구성: 538. Wireshark + C#으로 확인하는 ReceiveBufferSize(SO_RCVBUF), SendBufferSize(SO_SNDBUF) [3]
12531정성태2/5/20219075개발 환경 구성: 537. Wireshark + C#으로 확인하는 PSH flag와 Nagle 알고리듬파일 다운로드1
12530정성태2/4/202113294개발 환경 구성: 536. Wireshark + C#으로 확인하는 TCP 통신의 Receive Window
12529정성태2/4/202110306개발 환경 구성: 535. Wireshark + C#으로 확인하는 TCP 통신의 MIN RTO [1]
12528정성태2/1/20219716개발 환경 구성: 534. Wireshark + C#으로 확인하는 TCP 통신의 MSS(Maximum Segment Size) - 윈도우 환경
12527정성태2/1/20219896개발 환경 구성: 533. Wireshark + C#으로 확인하는 TCP 통신의 MSS(Maximum Segment Size) - 리눅스 환경파일 다운로드1
12526정성태2/1/20217724개발 환경 구성: 532. Azure Devops의 파이프라인 빌드 시 snk 파일 다루는 방법 - Secure file
12525정성태2/1/20217432개발 환경 구성: 531. Azure Devops - 파이프라인 실행 시 빌드 이벤트를 생략하는 방법
12524정성태1/31/20218574개발 환경 구성: 530. 기존 github 프로젝트를 Azure Devops의 빌드 Pipeline에 연결하는 방법 [1]
12523정성태1/31/20218635개발 환경 구성: 529. 기존 github 프로젝트를 Azure Devops의 Board에 연결하는 방법
12522정성태1/31/202110154개발 환경 구성: 528. 오라클 클라우드의 리눅스 VM - 9000 MTU Jumbo Frame 테스트
12521정성태1/31/202110097개발 환경 구성: 527. 이더넷(Ethernet) 환경의 TCP 통신에서 MSS(Maximum Segment Size) 확인 [1]
12520정성태1/30/20218640개발 환경 구성: 526. 오라클 클라우드의 VM에 ping ICMP 여는 방법
12519정성태1/30/20217679개발 환경 구성: 525. 오라클 클라우드의 VM을 외부에서 접근하기 위해 포트 여는 방법
... 31  32  33  34  35  36  37  38  39  40  41  42  43  [44]  45  ...