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 항목이 생성됩니다.

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 드라이브에 확보가 됩니다. ^^




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







[최초 등록일: ]
[최종 수정일: 8/30/2021]

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)
12515정성태1/28/202110659웹: 41. Microsoft Edge - localhost에 대해 http 접근 시 무조건 https로 바뀌는 문제 [3]
12514정성태1/28/202110914.NET Framework: 1021. C# - 일렉트론 닷넷(Electron.NET) 소개 [1]파일 다운로드1
12513정성태1/28/20218958오류 유형: 698. electronize - User Profile 디렉터리에 공백 문자가 있는 경우 빌드가 실패하는 문제 [1]
12512정성태1/28/20218708오류 유형: 697. The program can't start because VCRUNTIME140.dll is missing from your computer. Try reinstalling the program to fix this problem.
12511정성태1/27/20218467Windows: 187. Windows - 도스 시절의 8.3 경로를 알아내는 방법
12510정성태1/27/20218864.NET Framework: 1020. .NET Core Kestrel 호스팅 - Razor 지원 추가 [1]파일 다운로드1
12509정성태1/27/20219773개발 환경 구성: 524. Jupyter Notebook에서 C#(F#, PowerShell) 언어 사용을 위한 환경 구성 [3]
12508정성태1/27/20218361개발 환경 구성: 523. Jupyter Notebook - Slide 플레이 버튼이 없는 경우
12507정성태1/26/20218486VS.NET IDE: 157. Visual Studio - Syntax Visualizer 메뉴가 없는 경우
12506정성태1/25/202111800.NET Framework: 1019. Microsoft.Tye 기본 사용법 소개 [1]
12505정성태1/23/20219468.NET Framework: 1018. .NET Core Kestrel 호스팅 - Web API 추가 [1]파일 다운로드1
12504정성태1/23/202110582.NET Framework: 1017. .NET 5에서의 네트워크 라이브러리 개선 (2) - HTTP/2, HTTP/3 관련 [1]
12503정성태1/21/20218929오류 유형: 696. C# - HttpClient: Requesting HTTP version 2.0 with version policy RequestVersionExact while HTTP/2 is not enabled.
12502정성태1/21/20219703.NET Framework: 1016. .NET Core HttpClient의 HTTP/2 지원파일 다운로드1
12501정성태1/21/20218754.NET Framework: 1015. .NET 5부터 HTTP/1.1, 2.0 선택을 위한 HttpVersionPolicy 동작 방식파일 다운로드1
12500정성태1/21/20219333.NET Framework: 1014. ASP.NET Core(Kestrel)의 HTTP/2 지원 여부파일 다운로드1
12499정성태1/20/202110526.NET Framework: 1013. .NET Core Kestrel 호스팅 - 포트 변경, non-localhost 접속 지원 및 https 등의 설정 변경 [1]파일 다운로드1
12498정성태1/20/20219508.NET Framework: 1012. .NET Core Kestrel 호스팅 - 비주얼 스튜디오의 Kestrel/IIS Express 프로파일 설정
12497정성태1/20/202110491.NET Framework: 1011. C# - OWIN Web API 예제 프로젝트 [1]파일 다운로드2
12496정성태1/19/20219356.NET Framework: 1010. .NET Core 콘솔 프로젝트에서 Kestrel 호스팅 방법 [1]
12495정성태1/19/202111302웹: 40. IIS의 HTTP/2 지원 여부 - h2, h2c [1]
12494정성태1/19/202110604개발 환경 구성: 522. WSL2 인스턴스와 호스트 측의 Hyper-V에 운영 중인 VM과 네트워크 연결을 하는 방법 [2]
12493정성태1/18/20218883.NET Framework: 1009. .NET 5에서의 네트워크 라이브러리 개선 (1) - HTTP 관련 [1]파일 다운로드1
12492정성태1/17/20218297오류 유형: 695. ASP.NET 0x80131620 Failed to bind to address
12491정성태1/16/20219985.NET Framework: 1008. 배열을 반환하는 C# COM 개체의 메서드를 C++에서 사용 시 메모리 누수 현상 [1]파일 다운로드1
12490정성태1/15/20219499.NET Framework: 1007. C# - foreach에서 열거 변수의 타입을 var로 쓰면 object로 추론하는 문제 [1]파일 다운로드1
... 31  32  33  34  35  36  37  38  39  40  41  42  43  44  [45]  ...