Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

WSL 2 - docker-desktop-data, docker-desktop (%LOCALAPPDATA%\Docker\wsl\data\ext4.vhdx) 파일을 다른 디렉터리로 옮기는 방법

Docker Desktop이 사용하는 리눅스 인스턴스는 원래 Hyper-V의 "DockerDesktopVM"에서 호스팅되므로 만약 해당 vhdx의 파일 크기가 커져 C 드라이브에 있는 것이 부담스럽다면 Hyper-V 레벨에서 변경만 해주면 됩니다.

하지만, "Use the WSL 2 based engine" 옵션을 켜면 Hyper-V가 아닌 별도의 vhdx로 빠져 WSL 2 인스턴스와 연동이 됩니다. 실제로 WSL 2로 활성화하면 다음과 같이 docker-desktop-data, docker-desktop 항목이 생성됩니다. (2024-11-11 업데이트: Docker Desktop 4.3부터 docker-desktop-data는 더 이상 신규 생성을 하지 않습니다.)

C:\temp> wsl -l -v
  NAME                   STATE           VERSION
* Ubuntu20.04            Running         2
  docker-desktop-data    Stopped         2
  docker-desktop         Stopped         2

현재 Stopped로 나오는데요, 왜냐하면 "Docker Desktop"을 실행하지 않았기 때문입니다. 따라서 그걸 실행시킨 후에 다시 확인하면,

C:\temp> wsl -l -v
  NAME                   STATE           VERSION
* Ubuntu20.04            Running         2
  docker-desktop-data    Running         2
  docker-desktop         Running         2

Running으로 나오고, WSL 2 backend로 지정된 인스턴스(위의 경우 Ubuntu20.04)는 이렇게 /mnt/wsl로 추가 마운팅이 이뤄집니다.

$ df
Filesystem     1K-blocks      Used Available Use% Mounted on
/dev/sdb       263174212   5592496 244143560   3% /
tmpfs           13092504    410040  12682464   4% /mnt/wsl
tools          248984568 223661284  25323284  90% /init
...[생략]...
/dev/sdd       263174212   8056920 241679136   4% /mnt/wsl/docker-desktop-data/isocache
none            13092504        12  13092492   1% /mnt/wsl/docker-desktop/shared-sockets/host-services
/dev/sdc       263174212    134176 249601880   1% /mnt/wsl/docker-desktop/docker-desktop-proxy
/dev/loop0        404596    404596         0 100% /mnt/wsl/docker-desktop/cli-tools

참고로, "Docker Desktop"이 실행되지 않으면 다음과 같이 마운팅 결과가 나옵니다.

$ df
Filesystem     1K-blocks      Used Available Use% Mounted on
/dev/sdb       263174212   5591704 244144352   3% /
tmpfs           13092504         0  13092504   0% /mnt/wsl
tools          248984568 223664044  25320524  90% /init
...[생략]...




docker-desktop 볼륨의 물리적인 파일 위치는 "%LOCALAPPDATA%\Docker\wsl\data\ext4.vhdx"에 해당합니다. 그리고 docker 운영이 커질수록 이 파일의 크기는 그에 맞게 증가합니다. 문제는, docker-desktop-data와 docker-desktop의 크기가 무시 못 할 정도로 커질 수 있는데요, 가령 제 경우에는 8GB까지 육박했습니다.

상황에 따라서는 C 드라이브에 8GB를 점유하는 것이 부담스러울 수 있는데요, 다행히 ext4.vhdx 파일을 다른 드라이브로 옮길 수 있는 방법이 있고 이에 대해서는 전에 한 번 설명했던 것과 같습니다.

WSL 인스턴스 export/import 방법 및 단축 아이콘 설정 방법
; https://www.sysnet.pe.kr/2/0/12569

정리하면 다음과 같이 하면 됩니다.

wsl --shutdown
wsl --export docker-desktop-data e:\temp\docker-desktop-data.tar
wsl --unregister docker-desktop-data
wsl --import docker-desktop-data e:\wsl2\data e:\temp\docker-desktop-data.tar --version 2

del e:\temp\docker-desktop-data.tar

위와 같이 실행하면 "%LOCALAPPDATA%\Docker\wsl\data"에 있던 ext4.vhdx 파일이 e:\wsl2 디렉터리로 이동합니다. 그리고 docker-desktop 인스턴스의 경우 용량은 작지만 그래도 일관성을 위해 함께 이전하는 것이 좋을 듯합니다. ^^

wsl --export docker-desktop e:\temp\docker-desktop.tar
wsl --unregister docker-desktop
wsl --import docker-desktop e:\wsl2\docker e:\temp\docker-desktop.tar --version 2

이렇게 되면 (제 경우에) 8GB가 C 드라이브에 확보가 됩니다. ^^




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







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

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

비밀번호

댓글 작성자
 




[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13981정성태8/1/2025233오류 유형: 971. CentOS 7에서 yum 사용 시 "Could not resolve host: mirrorlist.centos.org; Unknown error"
13980정성태7/31/2025300Linux: 119. eBPF - BPF_PROG_TYPE_CGROUP_SOCK 유형에서 정상 동작하지 않는 BPF_CORE_READ (2)
13979정성태7/30/2025318Linux: 118. eBPF - BPF_PROG_TYPE_CGROUP_SOCK 유형에서 정상 동작하지 않는 BPF_CORE_READ
13978정성태7/29/2025432오류 유형: 970. 파일 복사 시 "Data error (cyclic redundancy check). (0x80070017)" 에러
13977정성태7/28/2025544닷넷: 2349. C# 14 - (5) 문자열 리터럴을 utf-8 인코딩으로 저장파일 다운로드1
13976정성태7/25/2025793닷넷: 2348. C# - 카카오 카나나 모델 + Microsoft.ML.OnnxRuntimeGenAI 예제파일 다운로드1
13975정성태7/23/2025930닷넷: 2347. C# 14 - (4) 형식 인자가 없는 제네릭 타입의 nameof 지원파일 다운로드1
13974정성태7/22/20251236닷넷: 2346. C# 14 - (3) Span 타입과 배열 간의 암시적 형변환파일 다운로드1
13973정성태7/21/20251112닷넷: 2345. C# - 배열 및 Span의 공변성파일 다운로드1
13972정성태7/21/20251337닷넷: 2344. C#의 Identity conversion 의미파일 다운로드1
13971정성태7/17/20251438닷넷: 2343. C# 14 - (2) 속성 구문에서 문맥 키워드로 추가되는 field 예약어파일 다운로드1
13970정성태7/17/20251387닷넷: 2342. C# 14 - (1) (예약)
13969정성태7/17/20251434닷넷: 2341. snap으로 설치한 .NET 리눅스 실행 환경
13968정성태7/16/20251316오류 유형: 969. lddtree - TypeError: 'type' object is not subscriptable
13967정성태7/16/20251844오류 유형: 968. snap으로 설치한 "dotnet run" 실행 시 "undefined symbol: _dl_audit_symbind_alt, version GLIBC_PRIVATE" 오류
13966정성태7/15/20252392디버깅 기술: 223. WinDbg - .kframes 명령어
13965정성태7/11/20251675오류 유형: 967. 디버깅 모드로 실행 시 "Could not find file 'C:\Program Files\IIS Express\Oracle.DataAccess.Common.Configuration.Section.xsd'" 예외
13964정성태7/10/20252340닷넷: 2340. C# - Win32 Multimedia Timer 주기파일 다운로드1
13963정성태7/8/20251880VS.NET IDE: 202. Visual Studio 2022 + Copilot 기본 사용법
13962정성태7/7/20251899스크립트: 79. 파이썬 - onnxruntime_genai에서 지원하지 않는 모델 사용
13961정성태7/5/20251605디버깅 기술: 222. WinDbg 분석 사례 - IISreset 시점에 w3wp.exe의 crash 발생
13960정성태7/3/20252791개발 환경 구성: 752. ProcDump - C/C++ 예외 코드 필터를 지정한 덤프 생성 [2]
13959정성태6/25/20251817오류 유형: 966. Ubuntu - ping: connect: Network is unreachable
13958정성태6/21/20252494닷넷: 2339. C# - Phi-4-multimodal 모델의 GPU 가속 방법 (ORT 사용)파일 다운로드1
13957정성태6/20/20252940닷넷: 2338. C# / Foundry Local - Phi-4-multimodal 모델을 사용하는 방법 [1]
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...