Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 556. WSL 인스턴스 초기 설정 명령어 [링크 복사], [링크+제목 복사]
조회: 9785
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)
(시리즈 글이 11개 있습니다.)
개발 환경 구성: 303. Windows 10 Bash Shell - 한글 환경을 영문으로 바꾸고 싶다면?
; https://www.sysnet.pe.kr/2/0/11058

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

개발 환경 구성: 556. WSL 인스턴스 초기 설정 명령어
; https://www.sysnet.pe.kr/2/0/12573

개발 환경 구성: 581. Windows에서 WSL로 파일 복사 시 root 소유권으로 적용되는 문제
; https://www.sysnet.pe.kr/2/0/12718

Linux: 46. WSL 환경에서 find 명령을 사용해 파일을 찾는 방법
; https://www.sysnet.pe.kr/2/0/12864

개발 환경 구성: 617. 윈도우 WSL 환경에서 같은 종류의 리눅스를 다중으로 설치하는 방법
; https://www.sysnet.pe.kr/2/0/12878

개발 환경 구성: 619. Windows Server에서 WSL을 위한 리눅스 배포본을 설치하는 방법
; https://www.sysnet.pe.kr/2/0/12882

Linux: 47. WSL - shell script에서 설정한 환경 변수가 스크립트 실행 후 반영되지 않는 문제
; https://www.sysnet.pe.kr/2/0/12918

Windows: 207. Windows Server 2022에 도입된 WSL 2
; https://www.sysnet.pe.kr/2/0/13073

개발 환경 구성: 694. Windows 디렉터리 경로를 WSL의 /mnt 포맷으로 구하는 방법
; https://www.sysnet.pe.kr/2/0/13484

Linux: 67. WSL 환경 + mlocate(locate) 도구의 /mnt 디렉터리 검색 문제
; https://www.sysnet.pe.kr/2/0/13503




WSL 인스턴스 초기 설정 명령어

Microsoft Store에 방문, Ubuntu 20.04를 검색해,

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

새로 설치하면 shell 창이 하나 뜨고 계정 정보 입력, 이후 sudo 명령어에 암호 입력을 (편의상) 생략하기 위해 sudoers 파일을 업데이트합니다. (WSL은 Windows 10 개인 운영체제에서 동작시키므로 편의상 이 작업을 해두지만, 실제 리눅스 머신에서는 권장하지 않습니다.)

$ sudo visudo

// 또는,

$ sudo nano /etc/sudoers

%sudo ALL=(ALL:ALL) NOPASSWD: ALL

[centos 9: 별도 파일 생성]
$ pwd
/home/testusr

$ sudo cat /etc/sudoers.d/tesusr
tsetusr ALL=NOPASSWD: ALL

최초 설치 시에는, WSL 버전의 기본값이 1이므로 원한다면 이것을 2로 올려줍니다.

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

c:\temp> wsl --set-version Ubuntu-20.04 2

이후 인스턴스를 실행해 update & upgrade를 하고,

$ sudo apt update && sudo apt upgrade -y

이와 함께 .NET 5도 설치해 주고,
$ sudo apt-get install -y apt-transport-https && sudo apt-get install -y dotnet-sdk-5.0

기본적으로 WSL 인스턴스는 Store App의 특성상 %LOCALAPPDATA%\Packages 폴더에 생성되는데, 이것이 마음에 들지 않는다면 아래의 글을 통해 다른 디렉터리로 옮길 수 있습니다.

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




Docker Desktop for Windows와 연동하고 싶다면 "Settings" / "General"의 "Use the WSL 2 based engine" 옵션을 체크하고 "Apply & Restart" 버튼을 누릅니다. 해당 구성이 완료되면 이제 WSL 2 인스턴스에서 docker, kubectl 명령어 등이 사용가능합니다.

$ which docker
/usr/bin/docker

$ which kubectl
/usr/local/bin/kubectl

여기서 유의할 것은, 해당 바이너리들은 symbolic link여서,

$ ls /usr/bin/docker -l
lrwxrwxrwx 1 root root 48 Mar 18 15:29 /usr/bin/docker -> /mnt/wsl/docker-desktop/cli-tools/usr/bin/docker

$ ls /usr/local/bin/kubectl -l
lrwxrwxrwx 1 root root 55 Mar 18 15:29 /usr/local/bin/kubectl -> /mnt/wsl/docker-desktop/cli-tools/usr/local/bin/kubectl

저런 마운팅이 "Docker Desktop for Windows"가 실행 중인 상태에서만 연결된다는 점입니다. (즉, docker desktop을 중지했다면 WSL 인스턴스 측에서 docker, kubectl 명령어를 수행할 수 없습니다.)

또한, 기본적으로 Docker Desktop for Windows는 "DockerDesktopVM"을 띄워 그 안에 docker를 구성하는 식으로 동작하지만, "Use the WSL 2 based engine" 옵션을 선택하는 경우에는 docker 환경을 WSL 2 인스턴스내에 구성하므로 DockerDesktopVM을 사용할 필요가 없어 해당 VM을 더 이상 사용하지 않습니다.




하는 김에 현재 사용자 계정을 docker 그룹에도 등록해 주시고,

$ sudo usermod -aG docker ${USER}

// 반영을 위해 로그아웃 후, 로그인

정상동작하는지 확인합니다.

$ docker run hello-world

/*
// 만약 exited인 컨테이너를 모두 삭제하고 싶다면,
[리눅스]
docker rm $(docker ps -a -f "status=exited" -q)

[윈도우]
FOR /F %i IN ('docker ps -a -f "status=exited" -q') do docker rm %i

// 또는, 모든 컨테이너를 삭제하고 싶다면,
[리눅스]
docker rm $(docker ps -a -q)

[윈도우]
FOR /F %i IN ('docker ps -a -q') do docker rm %i
*/




당연하겠지만, 호스트 측에 Docker Desktop for Windows와 "Use the WSL 2 based engine" 옵션을 켰다고 해서 쿠버네티스 환경까지 구성된 것은 아닙니다.

$ kubectl config view
apiVersion: v1
clusters: null
contexts: null
current-context: ""
kind: Config
preferences: {}
users: null

WSL에 k8s를 구성하려면 Settings / Kubernetes / "Enable Kubernetes" 옵션을 켜고 "Apply & Restart" 버튼을 눌러야 하는데, 만약 구성에 실패한다면 "Use the WSL 2 based engine" 옵션을 끄고 구성합니다.

c:\temp> kubectl config view
apiVersion: v1
clusters:
- cluster:
    certificate-authority-data: DATA+OMITTED
    server: https://kubernetes.docker.internal:6443
  name: docker-desktop
contexts:
- context:
    cluster: docker-desktop
    user: docker-desktop
  name: docker-desktop
current-context: docker-desktop
kind: Config
preferences: {}
users:
- name: docker-desktop
  user:
    client-certificate-data: REDACTED
    client-key-data: REDACTED




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 12/15/2023]

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

비밀번호

댓글 작성자
 



2022-07-04 09시28분
윈도우 10/11 환경에서 리눅스(wsl2)의 zsh 꾸미기
; https://forum.dotnetdev.kr/t/10-11-wsl2-zsh/4007
정성태

... 16  17  18  [19]  20  21  22  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
13154정성태11/3/20225753.NET Framework: 2063. .NET 5+부터 지원되는 GC.GetGCMemoryInfo파일 다운로드1
13153정성태11/2/20227037.NET Framework: 2062. C# - 코드로 재현하는 소켓 상태(SYN_SENT, SYN_RECV)
13152정성태11/1/20225655.NET Framework: 2061. ASP.NET Core - DI로 추가한 클래스의 초기화 방법 [1]
13151정성태10/31/20225766C/C++: 161. Windows 11 환경에서 raw socket 테스트하는 방법파일 다운로드1
13150정성태10/30/20225829C/C++: 160. Visual Studio 2022로 빌드한 C++ 프로그램을 위한 다른 PC에서 실행하는 방법
13149정성태10/27/20225727오류 유형: 825. C# - CLR ETW 이벤트 수신이 GCHeapStats_V1/V2에 대해 안 되는 문제파일 다운로드1
13148정성태10/26/20225738오류 유형: 824. msbuild 에러 - error NETSDK1005: Assets file '...\project.assets.json' doesn't have a target for 'net5.0'. Ensure that restore has run and that you have included 'net5.0' in the TargetFramew
13147정성태10/25/20224838오류 유형: 823. Visual Studio 2022 - Unable to attach to CoreCLR. The debugger's protocol is incompatible with the debuggee.
13146정성태10/24/20225676.NET Framework: 2060. C# - Java의 Xmx와 유사한 힙 메모리 최댓값 제어 옵션 HeapHardLimit
13145정성태10/21/20225952오류 유형: 822. db2 - Password validation for user db2inst1 failed with rc = -2146500508
13144정성태10/20/20225789.NET Framework: 2059. ClrMD를 이용해 윈도우 환경의 메모리 덤프로부터 닷넷 모듈을 추출하는 방법파일 다운로드1
13143정성태10/19/20226323오류 유형: 821. windbg/sos - Error code - 0x000021BE
13142정성태10/18/20225138도서: 시작하세요! C# 12 프로그래밍
13141정성태10/17/20226807.NET Framework: 2058. [in,out] 배열을 C#에서 C/C++로 넘기는 방법 - 세 번째 이야기파일 다운로드1
13140정성태10/11/20226173C/C++: 159. C/C++ - 리눅스 환경에서 u16string 문자열을 출력하는 방법 [2]
13139정성태10/9/20226003.NET Framework: 2057. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프로부터 모든 닷넷 모듈을 추출하는 방법파일 다운로드1
13138정성태10/8/20227310.NET Framework: 2056. C# - await 비동기 호출을 기대한 메서드가 동기로 호출되었을 때의 부작용 [1]
13137정성태10/8/20225662.NET Framework: 2055. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프로부터 닷넷 모듈을 추출하는 방법
13136정성태10/7/20226237.NET Framework: 2054. .NET Core/5+ SDK 설치 없이 dotnet-dump 사용하는 방법
13135정성태10/5/20226482.NET Framework: 2053. 리눅스 환경의 .NET Core 3/5+ 메모리 덤프를 분석하는 방법 - 두 번째 이야기
13134정성태10/4/20225223오류 유형: 820. There is a problem with AMD Radeon RX 5600 XT device. For more information, search for 'graphics device driver error code 31'
13133정성태10/4/20225542Windows: 211. Windows - (commit이 아닌) reserved 메모리 사용량 확인 방법 [1]
13132정성태10/3/20225441스크립트: 42. 파이썬 - latexify-py 패키지 소개 - 함수를 mathjax 식으로 표현
13131정성태10/3/20228151.NET Framework: 2052. C# - Windows Forms의 데이터 바인딩 지원(DataBinding, DataSource) [2]파일 다운로드1
13130정성태9/28/20225192.NET Framework: 2051. .NET Core/5+ - 에러 로깅을 위한 Middleware가 동작하지 않는 경우파일 다운로드1
13129정성태9/27/20225484.NET Framework: 2050. .NET Core를 IIS에서 호스팅하는 경우 .NET Framework CLR이 함께 로드되는 환경
... 16  17  18  [19]  20  21  22  23  24  25  26  27  28  29  30  ...