Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 473. Windows nanoserver에 대한 docker pull의 태그 사용 [링크 복사], [링크+제목 복사],
조회: 19522
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

Windows nanoserver에 대한 docker pull의 태그 사용

"nanoserver" 이미지를 받아볼까요? ^^

C:\temp> docker pull mcr.microsoft.com/windows/nanoserver
Using default tag: latest
Error response from daemon: manifest for mcr.microsoft.com/windows/nanoserver:latest not found: manifest unknown: manifest unknown

위와 같이 기본적으로 tag를 안 붙이는 경우 ":latest"로 접근하게 되는데 "모든" 이미지들이 꼭 "latest"가 붙은 이미지를 함께 배포하는 것은 아니므로 해당 이미지 배포본의,

Nano Server
; https://hub.docker.com/_/microsoft-windows-nanoserver

도움말을 찾아 지원되는 태그를 확인하는 것이 좋습니다.

Note: This repo does not publish or maintain a latest tag. Please declare a specific tag when pulling or referencing images from this repo.

참고로, 위의 링크에도 나오지만 nanoserver의 지원되는 모든 태그 목록은 다음과 같은 링크로 구할 수 있습니다.

List of all available tags for windows/nanoserver 
; https://mcr.microsoft.com/v2/windows/nanoserver/tags/list




그런데 지원된다고 하는 태그조차도 manifest 목록에 없다고 할 수 있습니다.

C:\temp> docker pull mcr.microsoft.com/windows/nanoserver:1903
1903: Pulling from windows/nanoserver
no matching manifest for windows/amd64 10.0.14393 in the manifest list entries

그래서 "List of all available tags for windows/nanoserver" 목록을 통해 근사치 태그로 접근해도 이번에는 현재 운영체제와 맞지 않는 이미지라고 오류가 발생할 수 있습니다.

C:\temp> docker pull mcr.microsoft.com/windows/nanoserver:1903-amd64
1903-amd64: Pulling from windows/nanoserver
a Windows version 10.0.18362-based image is incompatible with a 10.0.17763 host

"docker info" 명령어로 확인해 보면,

Kernel Version: 10.0 17763 (17763.1.amd64fre.rs5_release.180914-1434)
Operating System: Windows Server 2019 Datacenter Version 1809 (OS Build 17763.1075)
OSType: windows
Architecture: x86_64
CPUs: 8

운영체제의 버전이 1809이므로 "1903-amd64"의 경우 그보다 최신 버전이므로 오류가 발생한 것입니다. 따라서, 태그 목록에서 1809 관련한 태그를 찾아 시도하면,

C:\temp> docker pull mcr.microsoft.com/windows/nanoserver:1809-amd64
1809-amd64: Pulling from windows/nanoserver
a35da61c3562: Pull complete
Digest: sha256:06281772b6a561411d4b338820d94ab1028fdeb076c85350bbc01e80c4bfa2b4
Status: Downloaded newer image for mcr.microsoft.com/windows/nanoserver:1809-amd64

휴~~~ 이제야 겨우 이미지를 내려받았습니다. ^^; 하지만, 만약 여러분이 운이 나빠 "Docker Desktop for Windows" 환경에서 테스트하는 경우라면 이런 오류도 만날 수 있습니다.

C:\temp> docker pull mcr.microsoft.com/windows/nanoserver:1809-amd64
1809-amd64: Pulling from windows/nanoserver
a35da61c3562: Downloading [==>                                                ]  5.405MB/101.1MB
image operating system "windows" cannot be used on this platform

그렇습니다, 현재 "Docker Desktop"이 "Linux Containers" 모드로 동작하고 있기 때문에 윈도우 이미지를 설치할 수 없는 것입니다. 트레이 아이콘으로 가서 "Switch to Windows containers..." 명령을 실행한 후에야 "nanoserver" 이미지를 설치할 수 있습니다.




만약 여러분들이 운이 나빠 "Windows Server 2016"을 가지고 있다면,

C:\temp> docker info
...[생략]... 
 Kernel Version: 10.0 14393 (14393.3541.amd64fre.rs1_release_inmarket.200218-2047)
 Operating System: Windows Server 2016 Standard Version 1607 (OS Build 14393.3542)
 OSType: windows
...[생략]...

"Version 1607"을 보고는 아마도 다음과 같이 시도할지도 모르겠습니다.

C:\temp> docker pull mcr.microsoft.com/windows/nanoserver:1607-amd64
Error response from daemon: manifest for mcr.microsoft.com/windows/nanoserver:1607-amd64 not found: manifest unknown: manifest unknown

아쉽게도 마이크로소프트는 1607-amd64 태그를 가진 nanoserver는 배포하지 않습니다. 대신 "1803-amd64"를 실행해 보면, 당연히 현재의 운영체제에서는 지원할 수 없다는 오류 메시지를 보게 됩니다.

C:\temp> docker pull mcr.microsoft.com/windows/nanoserver:1803-amd64
1803-amd64: Pulling from windows/nanoserver
a Windows version 10.0.17134-based image is incompatible with a 10.0.14393 host

Windows Server 2016의 경우에는, "OS Build" 버전의 정보까지 내려가서 태그를 달아야 합니다. 위에서 docker info로 본 OS Build는 14393.3542였는데, 그렇다고 해서 이 빌드 버전을 그대로 사용할 수는 없습니다.

C:\temp> docker pull mcr.microsoft.com/windows/nanoserver:10.0.14393.3542
Error response from daemon: manifest for mcr.microsoft.com/windows/nanoserver:10.0.14393.3542 not found: manifest unknown: manifest unknown

"List of all available tags for windows/nanoserver" 목록을 보고, 최대한 근사치의 태그를 찾아 시도해 보면 정상적으로 이미지를 다운로드할 수 있습니다.

C:\temp> docker pull mcr.microsoft.com/windows/nanoserver:10.0.14393.2430
10.0.14393.2430: Pulling from windows/nanoserver
bce2fbc256ea: Already exists
4a14bdf6da80: Pull complete
Digest: sha256:ba322999264cd8ecdfb3fcaec020c7a479ff63e6c4333d89d11d67ecbd96b2b3
Status: Downloaded newer image for mcr.microsoft.com/windows/nanoserver:10.0.14393.2430
mcr.microsoft.com/windows/nanoserver:10.0.14393.2430




결국, 여러분들이 nanoserver를 기반으로 한 Dockerfile을 만들 때 사용할 기반 이미지의 태그를,

FROM mcr.microsoft.com/windows/nanoserver:1809
...

주의 깊게 사용해야 합니다. 개발자의 환경에서는 Windows 10을 사용해 1903 nanoserver로 무심코 이미지를 생성할 수 있겠지만, 그것이 실 서버에 올라갈 때는 운영팀에서 (역시 무심코) 올리게 될 환경이 Windows Server 2019 서버일지라도 1809 버전 또는 1903 버전일 수 있으므로 그에 따라 혼란을 야기할 수 있습니다.




참고로 이와 관련한 공식 문서도 보시고. ^^

Windows container version compatibility
; https://learn.microsoft.com/en-us/virtualization/windowscontainers/deploy-containers/version-compatibility?tabs=windows-server-1909%2Cwindows-10-1909




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 3/9/2024]

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

비밀번호

댓글 작성자
 



2020-09-27 07시04분
[happyrami] 큰 도움이 되었습니다. 감사합니다. ^^
[guest]

... 181  182  183  184  185  186  187  188  189  190  191  192  [193]  194  195  ...
NoWriterDateCnt.TitleFile(s)
195정성태12/21/200516882    답변글 VC++: 25.1. ODBC 로그를 못 남길 때의 오류 화면
113정성태3/13/200517619VS.NET IDE: 24. [VPC] 타이머 동기화 기능 제거
110정성태11/14/200516573.NET Framework: 28. VS.NET 2005 / SQL Server 2005 베타 버전 재설치 또는 업그레이드 [1]
111정성태3/7/200515408    답변글 VS.NET IDE: 28.1. [추가] SQL 2005 / VS.NET 2005 2005-02 CTP 버전이 올라왔네요. [1]
112정성태11/14/200516695        답변글 VS.NET IDE: 28.2. [추가] VS.NET 2005 2005-02 CTP 버전에서 달라진 점 ( VC++ )
127정성태3/29/200514729        답변글 VS.NET IDE: 28.4. [추가] SQL 2005 2005-02 CTP 버전에서 달라진 점
123정성태3/25/200518605    답변글 .NET Framework: 28.3. Uninstalling software without using Add Remove Programs...
108정성태3/4/200518035.NET Framework: 27. 시스템 이벤트 로그에 쌓이는 {00020906-0000-0000-C000-000000000046} 보안에러
107정성태3/1/200518267COM 개체 관련: 15. COM: Control 유형인 경우, IObjectWithSite 를 구현해도 SetSite/GetSite 가 호출이 안됨
106정성태2/28/200517617COM 개체 관련: 14. 탐색기 "처럼" 파일 열기
105정성태2/28/200516666.NET Framework: 26. VS.NET 2005 : 설치 프로젝트 - .NET Framework 설치 강제화
139정성태11/14/200514846    답변글 .NET Framework: 26.1. ^^ 역시, 배려가 되어 있네요. 제가 못 찾은 것이었습니다.
104정성태2/27/200517539VS.NET IDE: 23. MSI 설치 중에 GetLocalTime / GetSystemTime API 사용
132정성태3/30/200517181    답변글 VS.NET IDE: 23.1. [추가]: MSI 설치 동작 원리
102정성태2/16/200519829.NET Framework: 25. Verify that you are a member of the 'Debugger Users' group on the server. [2]
101정성태2/15/200517589.NET Framework: 24. WMI Win32_NTLogEvent 관리 이벤트를 Windows 2000 에서는 "Access Denied" 가 발생하는 문제파일 다운로드1
100정성태2/15/200523665VS.NET IDE: 22. 방화벽 환경에서의 WMI 연결을 위한 포트 설정 [2]
99정성태2/15/200521618COM 개체 관련: 13. 비동기 Drag & Drop 구현 : IAsyncOperation
103정성태2/23/200517867    답변글 COM 개체 관련: 13.1. [관련 자료] 그외 Drag & Drop 링크파일 다운로드1
97정성태2/14/200520836VS.NET IDE: 21. 설치된 Platform SDK 버전확인 방법
96정성태2/14/200522858기타: 9. http://www.google.com/webhp?complete=1&hl=en 검색에 관해서.
95정성태2/14/200532195VS.NET IDE: 20. Win32 특권 정리 [1]
94정성태1/29/200523493VC++: 13. VS.NET 2005 VC++ 컴파일러 에러 : cannot instantiate abstract class
93정성태1/29/200519375VS.NET IDE: 19. 혹시 VS.NET 2005 Beta2(2004/12 CTP Team System 버전)이 다운이 자주 되나요? [2]
92정성태1/29/200518188.NET Framework: 23. Unmanaged 환경에서 Managed DLL에 정의된 메서드 호출 시 오류 확인하는 방법
91정성태11/14/200518786VC++: 12. VS.NET 2005 VC++ Debug: Expression: ( (state != ST_INVALID ) )
... 181  182  183  184  185  186  187  188  189  190  191  192  [193]  194  195  ...