WSL 2의 네트워크 통신 방법 - 두 번째 이야기
예전에 썼던,
WSL 2의 네트워크 통신 방법
; https://www.sysnet.pe.kr/2/0/12347
내용에 보강을 좀 더 해보겠습니다. 예전 내용에서 Host -> WSL 2 인스턴스로의 접근이 localhost(127.0.0.1)로 가능하다고 했습니다. 혹은 (보통 172.x.x.x로 시작하는) WSL 2 네트워크에 부여된 IP도 가능합니다.
재미있는 건, WSL 2 인스턴스 내에서는 소켓 바인딩을 "0.0.0.0"으로 할 수 없다는 점입니다. 그래서 다음과 같이 바인딩시키면,
$ nc -l 0.0.0.0 65300
// 또는, nc -l localhost 65300
// nc -l 127.0.0.1 65300
$ netstat -ano | grep 65300
tcp 0 0 0.0.0.0:65300 0.0.0.0:* LISTEN off (0.00/0/0)
위의 3개 명령어의 결과는 결국, 윈도우 호스트에서 127.0.0.1로 바인딩된 것을 확인할 수 있습니다.
c:\temp> netstat -ano | findstr 65300
TCP 127.0.0.1:65300 0.0.0.0:0 LISTENING 45924
더욱 재미있는 것은, (보통 윈도우 호스트 측에서 Hyper-V의 "vEthernet (WSL)" 가상 스위치가 제공하는) WSL 2 네트워크의 IP로 바인딩했을 때입니다.
$ ifconfig
eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 172.28.206.218 netmask 255.255.240.0 broadcast 172.28.207.255
...[생략]...
$ nc -l 172.28.206.218 65300
$ netstat -ano | grep 65300
tcp 0 0 172.28.206.218:65300 0.0.0.0:* LISTEN off (0.00/0/0)
이런 경우 윈도우 호스트 측에서 netstat 명령어로 확인이 안 됩니다. 그렇긴 해도, (물론 127.0.0.1로 접속은 안 되지만) 윈도우 호스트 측에서 172.28.206.218로 접속은 가능합니다.
c:\temp> netstat -ano | findstr 65300
c:\temp> telnet 127.0.0.1 65300
Connecting To 127.0.0.1...Could not open connection to the host, on port 65300: Connect failed
c:\temp> telnet 172.28.206.218 65300
...[연결]...
이것 때문에 한 가지 유의할 사항이 있습니다. 바인딩이 다른 경우 동일한 포트로 소켓을 여는 것이 가능하기 때문에, 자칫 WSL 2 인스턴스에서 포트를 열어 놓았다고 해도,
// WSL 2 인스턴스에서 실행
// 내부적으로는 0.0.0.0으로 바인딩, 외부적으로는 127.0.0.1로 바인딩
$ nc -l 0.0.0.0 65300
실수로 윈도우 측에서도 동일한 포트로 열어놓을 수 있습니다.
// WSL 2에서는 127.0.0.1로 바인딩되었기 때문에,
// 윈도우 호스트 측에서 0.0.0.0으로 바인딩 가능
c:\temp> netcat -l 0.0.0.0 65300 // 윈도우용 netcat
그럼 2개의 바인딩이 있고,
c:\temp> netstat -ano | findstr 65300
TCP 0.0.0.0:65300 0.0.0.0:0 LISTENING 39348
TCP 127.0.0.1:65300 0.0.0.0:0 LISTENING 45924
이후 윈도우 호스트 측에서 localhost 또는 127.0.0.1로 TCP 접속을 시도하면 (윈도우에서 실행한) netcat이 아닌 (WSL 2 환경에서 실행한) nc 측으로 접속이 됩니다.
보통, 상대방 주소를 "0.0.0.0"으로 지정할 수는 없으므로 테스트를 위해 127.0.0.1(localhost)로 접속하다 보면, 저런 상황과 겹치는 경우 왜 윈도우 측의 TCP 서버에 아무런 반응이 없는 것인지 혼란스러울 때가 있습니다. ^^
[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]