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

WSL 인스턴스 export/import 방법 및 단축 아이콘 설정 방법

기본적으로 WSL 인스턴스는 Store App의 특성상 %LOCALAPPDATA%\Packages 폴더에 생성됩니다. 예를 들어, 20.04 버전의 Ubuntu를 설치한 경우,

Ubuntu 20.04 LTS
; https://www.microsoft.com/en-us/p/ubuntu-2004-lts/9n6svws3rx71

해당 폴더로 가면 "CanonicalGroupLimited.Ubuntu20.04onWindows" 이름으로 시작하는 디렉터리를 하나 보게 될 것입니다.

%LOCALAPPDATA%\Packages\CanonicalGroupLimited.Ubuntu20.04onWindows_79rhkp1fndgsc

만약 해당 인스턴스 이미지를 다른 디렉터리로 옮기고 싶다면 export한 후,

c:\temp\wsl> wsl --export Ubuntu-20.04 Ubuntu-20.04-default.tar

c:\temp\wsl> wsl -l -v
  NAME                   STATE           VERSION
* Ubuntu-20.04           Converting      1
  docker-desktop-data    Running         2
  docker-desktop         Running         2

다른 디렉터리를 지정해 import를 하면 됩니다.

c:\temp\wsl> mkdir d:\wsldist

c:\temp\wsl> wsl.exe --import Ubuntu20.04 d:\wsldist\Ubuntu20.04 c:\temp\wsl\Ubuntu-20.04-default.tar

c:\temp\wsl> wsl -l -v
  NAME                   STATE           VERSION
* Ubuntu-20.04           Stopped         1
  docker-desktop-data    Running         2
  Ubuntu20.04            Installing      1
  docker-desktop         Running         2

보는 바와 같이 기존 인스턴스가 있는 상태에서 복사가 된 것이므로 원한다면 이전 것은 삭제해도 됩니다.

c:\temp\wsl> wsl --unregister Ubuntu-20.04
Unregistering...

위의 명령어로 %LOCALAPPDATA%\Packages\CanonicalGroupLimited.Ubuntu20.04onWindows_79rhkp1fndgsc의 "LocalState" 하위 폴더에 있는 ext4.vhdx 파일 또는 "rootfs" 디렉터리가 삭제됩니다. 그리고 원한다면 default 인스턴스도 새롭게 바꿔주는 것으로 마무리할 수 있겠고!

D:\wsldist> wsl --set-default Ubuntu20.04

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

이런 식으로 인스턴스를 옮긴 경우 문제가 있다면, "시작" 메뉴에 Ubuntu WSL 인스턴스를 띄울 수 있는 아이콘이 없다는 점입니다. 기존에 "Ubuntu 20.04"를 설치해서 생긴 단축 아이콘은,

custom_wsl_instance_shortcut_1.png

여전히 이전 인스턴스의 아이콘이기 때문에 그걸 선택하면 %LOCALAPPDATA%\Packages\CanonicalGroupLimited.Ubuntu20.04onWindows_79rhkp1fndgsc 디렉터리에 다시 이미지가 구축됩니다.




이런 이유 때문에, 새롭게 import한 인스턴스를 간편하게 실행시킬 우아한 방법이 없습니다.

일단, 간단하게는 해당 인스턴스를 --set-default로 지정했다면 wsl.exe를 실행하는 것으로 시작할 수 있습니다.

D:\wsldist> wsl
root@TestPC:/mnt/d/wsldist#

/* 또는, -d 인자로 인스턴스를 지정

D:\wsldist> wsl.exe -d Ubuntu20.04
*/

그런데, 프롬프트를 보면 "root@TestPC"의 root 계정으로 실행하기 때문에 시작 계정이 마음에 들지 않습니다. 실제로 이전의 "Ubuntu-20.04" 단축 아이콘으로 실행한 경우에는 시작부터 "testusr@TestPC:~$"라는 프롬프트가 떴습니다.

다행히 시작 계정은 wsl.exe의 -u 옵션으로 가능하기 때문에 다음과 같이 실행하는 것으로 바꿀 수 있습니다.

D:\wsldist> wsl -d Ubuntu20.04 -u testusr
testusr@TestPC:/mnt/d/wsldist$

/* 또는, 현재 윈도우의 로그인 사용자와 같은 계정을 wsl에 생성해 두었다면,

D:\wsldist> wsl.exe -d Ubuntu20.04 -u %USERNAME%
*/

/* 
또는, 기본 사용자 계정을 설정하고 싶다면 해당 리눅스 환경 내에서 /etc/wsl.conf 파일의 내용을 다음과 같이 설정합니다.

// Configure per distro launch settings with wslconf
// ; https://docs.microsoft.com/en-us/windows/wsl/wsl-config#configure-per-distro-launch-settings-with-wslconf


[user]
default=testusr
*/

자, 그럼 여기까지의 구성으로 새롭게 단축 아이콘을 만들 수 있습니다.

Name: Ubuntu20.04
Target: C:\Windows\system32\wsl.exe -d Ubuntu20.04 -u %USERNAME%

이렇게 하고 단축 아이콘을 두 번 클릭하면 되는데, 여전히 사소한 문제가 하나 거슬립니다. 즉, 현재 디렉터리가 "/mnt/c/Windows/system32"로 wsl.exe를 실행했을 때의 디렉터리를 pwd로 시작하고 있는 것입니다.

이것까지 맞춰주려면 단축 아이콘 설정의 "Start in"에 다음과 같은 경로를 지정하면 됩니다.

\\wsl$\Ubuntu20.04\home\%USERNAME%

이걸로 모두 끝입니다. 여기까지 구성한 단축 아이콘을 두 번 누르면,

custom_wsl_instance_shortcut_2.png

"Ubuntu 20.04 LTS" Store App의 동작이 그러했듯이 시작 프롬프트 경로가 동일하게 구성됩니다. ^^

testusr@TestPC:~$




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

[연관 글]






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

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)
13116정성태8/4/2022168.NET Framework: 2041. C# - Socket.Close 시 Socket.Receive 메서드에서 예외가 발생하는 문제파일 다운로드1
13115정성태8/3/2022244.NET Framework: 2040. C# - ValueTask와 Task의 성능 비교파일 다운로드1
13114정성태8/2/2022231.NET Framework: 2039. C# - Task와 비교해 본 ValueTask 사용법파일 다운로드1
13113정성태7/31/2022216.NET Framework: 2038. C# 11 - Span 타입에 대한 패턴 매칭 (Pattern matching on ReadOnlySpan<char>)
13112정성태7/30/2022255.NET Framework: 2037. C# 11 - 목록 패턴(List patterns)파일 다운로드1
13111정성태7/29/2022229.NET Framework: 2036. C# 11 - IntPtr/UIntPtr과 nint/nuint의 통합파일 다운로드1
13110정성태7/27/2022254.NET Framework: 2035. C# 11 - 새로운 연산자 ">>>" (Unsigned Right Shift)파일 다운로드1
13109정성태7/27/2022206VS.NET IDE: 177. 비주얼 스튜디오 2022를 이용한 (소스 코드가 없는) 닷넷 모듈 디버깅 - "외부 원본(External Sources)"
13108정성태7/26/2022156Linux: 53. container에 실행 중인 Golang 프로세스를 디버깅하는 방법
13107정성태7/25/2022124Linux: 52. Debian/Ubuntu 계열의 docker container에서 자주 설치하게 되는 명령어
13106정성태7/24/2022109오류 유형: 819. 닷넷 6 프로젝트의 "Conditional compilation symbols" 기본값 오류
13105정성태7/23/2022226.NET Framework: 2034. .NET Core/5+ 환경에서 (프로젝트가 아닌) C# 코드 파일을 입력으로 컴파일하는 방법 - 두 번째 이야기 [1]
13104정성태7/23/2022198Linux: 51. WSL - init에서 systemd로 전환하는 방법
13103정성태7/22/2022112오류 유형: 818. WSL - systemd-genie와 관련한 2가지(systemd-remount-fs.service, multipathd.socket) 에러
13102정성태7/19/2022185.NET Framework: 2033. .NET Core/5+에서는 구할 수 없는 HttpRuntime.AppDomainAppId
13101정성태7/15/2022156[내용 예약] (비어 있는 글)
13100정성태7/15/2022256.NET Framework: 2032. C# 11 - shift 연산자 재정의에 대한 제약 완화 (Relaxing Shift Operator)
13099정성태7/14/2022645.NET Framework: 2031. C# 11 - 사용자 정의 checked 연산자파일 다운로드1
13098정성태7/13/2022189개발 환경 구성: 647. Azure - scale-out 상태의 App Service에서 특정 인스턴스에 요청을 보내는 방법
13097정성태7/12/2022148오류 유형: 817. Golang - binary.Read: invalid type int32
13096정성태7/8/2022429.NET Framework: 2030. C# 11 - UTF-8 문자열 리터럴
13095정성태7/7/2022222Windows: 208. AD 도메인에 참여하지 않은 컴퓨터에서 Kerberos 인증을 사용하는 방법
13094정성태7/6/2022156오류 유형: 816. Golang - "short write" 오류 원인
13093정성태7/5/2022264.NET Framework: 2029. C# - HttpWebRequest로 localhost 접속 시 2초 이상 지연
13092정성태7/3/2022428.NET Framework: 2028. C# - HttpWebRequest의 POST 동작 방식파일 다운로드1
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...