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

(시리즈 글이 14개 있습니다.)
개발 환경 구성: 83. Hyper-V의 네트워크 유형 (1)
; https://www.sysnet.pe.kr/2/0/910

개발 환경 구성: 84. Hyper-V의 네트워크 유형 (2)
; https://www.sysnet.pe.kr/2/0/915

개발 환경 구성: 87. Hyper-V의 네트워크 유형 (3)
; https://www.sysnet.pe.kr/2/0/918

Windows: 59. Hyper-V Internal 네트워크 VM의 인터넷 접속
; https://www.sysnet.pe.kr/2/0/1335

개발 환경 구성: 330. Hyper-V VM의 Internal Network를 Private 유형으로 만드는 방법
; https://www.sysnet.pe.kr/2/0/11299

Windows: 174. WSL 2의 네트워크 통신 방법
; https://www.sysnet.pe.kr/2/0/12347

개발 환경 구성: 517. Hyper-V Internal 네트워크에 NAT을 이용한 인터넷 연결 제공
; https://www.sysnet.pe.kr/2/0/12352

개발 환경 구성: 522. WSL 2 인스턴스와 호스트 측의 Hyper-V에 운영 중인 VM과 네트워크 연결을 하는 방법
; https://www.sysnet.pe.kr/2/0/12494

개발 환경 구성: 656. Internal Network 유형의 스위치로 공유한 Hyper-V의 VM과 호스트가 통신이 안 되는 경우
; https://www.sysnet.pe.kr/2/0/13199

개발 환경 구성: 660. WSL 2 내부로부터 호스트 측의 네트워크로 UDP 데이터가 1개의 패킷으로만 제한되는 문제
; https://www.sysnet.pe.kr/2/0/13230

개발 환경 구성: 665. WSL 2의 네트워크 통신 방법 - 두 번째 이야기
; https://www.sysnet.pe.kr/2/0/13256

개발 환경 구성: 670. WSL 2에서 호스팅 중인 TCP 서버를 외부에서 접근하는 방법
; https://www.sysnet.pe.kr/2/0/13280

개발 환경 구성: 712. Windows - WSL 2의 네트워크 통신 방법 - 세 번째 이야기 (같은 IP를 공유하는 WSL 2 인스턴스)
; https://www.sysnet.pe.kr/2/0/13647

개발 환경 구성: 714. WSL 2 인스턴스와 호스트 측의 Hyper-V에 운영 중인 VM과 네트워크 연결을 하는 방법 - 두 번째 이야기
; https://www.sysnet.pe.kr/2/0/13658




WSL 2 인스턴스와 호스트 측의 Hyper-V에 운영 중인 VM과 네트워크 연결을 하는 방법 - 두 번째 이야기

지난번에 테스트한 글을,

WSL 2 인스턴스와 호스트 측의 Hyper-V에 운영 중인 VM과 네트워크 연결을 하는 방법
; https://www.sysnet.pe.kr/2/0/12494

아래의 글을 읽은 김에 한 번 더 해봤습니다. ^^

Allowing Windows Subsystem for Linux to communicate with Hyper-V VMs
; https://automatingops.com/allowing-windows-subsystem-for-linux-to-communicate-with-hyper-v-vms




Hyper-V를 호스팅하는 경우 WSL과 "Default Switch" 간의 네트워크는 분리돼 있습니다.

// Windows 호스팅 서버 (Hyper-V)에서 ipconfig 실행 결과

Ethernet adapter vEthernet (Default Switch):

   Connection-specific DNS Suffix  . :
   Link-local IPv6 Address . . . . . : fe80::c52e:bcaf:7ccb:3114%36
   IPv4 Address. . . . . . . . . . . : 172.23.240.1
   Subnet Mask . . . . . . . . . . . : 255.255.240.0
   Default Gateway . . . . . . . . . :

Ethernet adapter vEthernet (WSL (Hyper-V firewall)):

   Connection-specific DNS Suffix  . :
   Link-local IPv6 Address . . . . . : fe80::ace:43c2:3a85:56b5%62
   IPv4 Address. . . . . . . . . . . : 172.18.208.1
   Subnet Mask . . . . . . . . . . . : 255.255.240.0
   Default Gateway . . . . . . . . . :

// WSL 2 Ubuntu 20.04 인스턴스에서 ifconfig 실행 결과

eth0: flags=4163  mtu 1500
        inet 172.18.214.61  netmask 255.255.240.0  broadcast 172.18.223.255
        ...[생략]...

// Hyper-V VM에 설치된 윈도우 VM에서 ipconfig 실행 결과 (Default Switch에 연결된 경우)

Ethernet adapter 이더넷 3:

   Connection-specific DNS Suffix  . : mshome.net
   Link-local IPv6 Address . . . . . : fe80::c2d7:20ff:31bf:6e94%4
   IPv4 Address. . . . . . . . . . . : 172.23.240.28
   Subnet Mask . . . . . . . . . . . : 255.255.240.0
   Default Gateway . . . . . . . . . : 172.23.240.1

따라서 호스트 측에서는 WSL 2와 VM 모두에 ping이 잘 동작합니다.

ping 172.18.214.61  // Host -> WSL 2: OK
ping 172.23.240.28  // Host -> VM: OK

반면, WSL 2와 VM 간의 ping은 모두 동작하지 않는데요, 이유는 기본적으로 중계를 하지 않기 때문입니다.

PS C:\temp> Get-NetIPInterface | where { $_.InterfaceAlias -eq 'vEthernet (WSL (Hyper-V firewall))' } | Select-Object ifIndex,InterfaceAlias,ConnectionState,Forwarding

ifIndex InterfaceAlias                     ConnectionState Forwarding
------- --------------                     --------------- ----------
     62 vEthernet (WSL (Hyper-V firewall))       Connected   Disabled // IPv6
     62 vEthernet (WSL (Hyper-V firewall))       Connected   Disabled // IPv4


PS C:\temp> Get-NetIPInterface | where { $_.InterfaceAlias -eq 'vEthernet (Default Switch)' } | Select-Object ifIndex,InterfaceAlias,ConnectionState,Forwarding

ifIndex InterfaceAlias             ConnectionState Forwarding
------- --------------             --------------- ----------
     36 vEthernet (Default Switch)       Connected   Disabled // IPv6
     36 vEthernet (Default Switch)       Connected   Disabled // IPv4

저렇게 Forwarding 설정이 꺼져 있는데요, 따라서 그걸 켜주면,

Get-NetIPInterface | where { $_.InterfaceAlias -eq 'vEthernet (WSL (Hyper-V firewall))' } | Set-NetIPInterface -Forwarding Enabled -Verbose

Get-NetIPInterface | where { $_.InterfaceAlias -eq 'vEthernet (Default Switch)' } | Set-NetIPInterface -Forwarding Enabled -Verbose

이후 서로 간에 ping이 잘 동작합니다.

ping 172.23.240.28  // WSL 2 -> VM: OK
ping 172.18.214.61  // VM -> WSL 2: OK

재미있는 건, 이러한 양방향 Forwarding은 "Default Switch"에 대해서만 가능하고, "Internal Network" 유형에 대해서는 약간 다른 동작을 합니다.

[VM 측이 Internal Network 유형인 경우]
VM -> WSL 2: Failed (Forwarding 설정 여부와 무관)
WSL 2 -> VM: OK (Forwarding 설정 여부와 무관)

지난 글을 쓸 때까지만 해도 WSL 2에서 (Internal Network에 속한) VM으로 불가능했던 것으로 아는데, 아마도 WSL 2 패치 과정에서 현재는 지원하게 된 것으로 보입니다. 반면 그 반대로 VM에서 WSL 2 인스턴스로는 ping이 되지 않습니다. 대신 ping을 제외하고는 일반적인 TCP/UDP 통신이라면 호스팅을 경유한 포트 포워딩으로 해결할 수 있을 텐데요, 단지 ping의 경우 ICMP 프로토콜이므로 포트가 없어 테스트할 수 없습니다.




한 가지 더 첨언하자면, 원래 ping을 위한 echo 요청은,

Windows 7/2008에서 ping을 위한 echo 요청 열기
; https://www.sysnet.pe.kr/2/0/780

Windows Defender Firewall with Advanced Security에서 "File and Printer Sharing" 범주의 ICMPv4-In, ICMPv6-In 규칙으로 제어합니다.

File and Printer Sharing (Echo Request - ICMPv4-In)
File and Printer Sharing (Echo Request - ICMPv6-In)

하지만, WSL 2 인스턴스에서 ("Default Switch"로 연결된) Hyper-V VM으로 ping을 하는 경우에는 저 규칙으로 열리지 않고 대신 "Virtual Machine Monitoring" 범주의 항목으로 열어야 합니다.

Virtual Machine Monitoring (Echo Request - ICMPv4-In)
Virtual Machine Monitoring (Echo Request - ICMPv6-In)

여기서 더 재미있는 것은, ("Default Switch"가 아닌) "Internal Network" 유형에 속한 VM인 경우에는 다시 "File and Printer Sharing" 범주의 ICMPv4-In, ICMPv6-In 규칙으로 열어야 WSL 2 인스턴스에서 ping이 됩니다. 마치, 윈도우 호스트 측에서 VM으로 ping을 하는 것과 유사하다고 볼 수 있습니다.




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







[최초 등록일: ]
[최종 수정일: 7/1/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)
14000정성태8/18/2025287오류 유형: 979. ERROR: failed to solve: failed to read dockerfile: open Dockerfile: no such file or directory
13999정성태8/15/2025853닷넷: 2355. C# 14 - (8) null 조건부 연산자 개선 - 대입문에도 사용 가능파일 다운로드1
13998정성태8/14/2025886닷넷: 2354. C# 14 - (7) 확장 메서드에 정적 메서드와 속성 지원을 위한 전용 구문 추가파일 다운로드1
13997정성태8/14/20251055Linux: 120. docker 컨테이너로 매핑된 볼륨에 컨테이너 측의 사용자 ID를 유지하면서 복사하는 방법
13996정성태8/13/2025614오류 유형: 978. Unable to find the requested .Net Framework Data Provider.
13995정성태8/13/2025655개발 환경 구성: 754. Visual C++ - 리눅스 빌드를 위한 Ubuntu 18 docker 컨테이너 설정
13994정성태8/12/2025657오류 유형: 977. SQL Server - User, group, or role '...' already exists in the current database. (Microsoft SQL Server, Error: 15023)
13993정성태8/11/2025992오류 유형: 976. Microsoft.ML.OnnxRuntimeGenAI 패키지 사용 시 "cublasLt64_12.dll" which is missing. (Error 126: "The specified module could not be found.") 오류
13992정성태8/11/20251172닷넷: 2353. C# - Foundry Local을 이용한 gpt-oss-20b 모델 사용파일 다운로드1
13991정성태8/9/20251106오류 유형: 975. winget - Foundry Local 패키지 업데이트가 안 되는 문제
13990정성태8/8/2025840Windows: 283. Time zone 설정이 없는 Windows Server 2025
13989정성태8/8/20251239닷넷: 2352. C# - Windows S-mode 환경인지 체크하는 방법파일 다운로드1
13988정성태8/8/20251380오류 유형: 974. 비주얼 스튜디오 업데이트 시 잠김 파일 경고 - Visual Studio Standard Collector Service 150 (VSStandardCollectorService150)
13987정성태8/7/20251043닷넷: 2351. C# 14 - (6) event와 생성자에도 partial 메서드 적용파일 다운로드1
13986정성태8/6/20251134닷넷: 2350. C# 14 - (5) 람다 매개 변수에 접근자가 있는 경우에도 타입 생략 가능파일 다운로드1
13985정성태8/6/20251498오류 유형: 973. "wsl --install" 명령어 수행 시 "The server name or address could not be resolved"
13984정성태8/6/20251258Windows: 282. 윈도우 운영체제에 추가된 ssh 서버(Win32-OpenSSH)
13983정성태8/4/20251352오류 유형: 972. Microsoft.Data.SqlClient 6.1.0 버전부터 .NET 8 이상만 지원
13982정성태8/2/20251784개발 환경 구성: 753. CentOS 7 컨테이너 내에서 openssh 서버 호스팅
13981정성태8/1/20251432오류 유형: 971. CentOS 7에서 yum 사용 시 "Could not resolve host: mirrorlist.centos.org; Unknown error"
13980정성태7/31/20251591Linux: 119. eBPF - BPF_PROG_TYPE_CGROUP_SOCK 유형에서 정상 동작하지 않는 BPF_CORE_READ (2)
13979정성태7/30/20251894Linux: 118. eBPF - BPF_PROG_TYPE_CGROUP_SOCK 유형에서 정상 동작하지 않는 BPF_CORE_READ
13978정성태7/29/20251709오류 유형: 970. 파일 복사 시 "Data error (cyclic redundancy check). (0x80070017)" 에러
13977정성태7/28/20252029닷넷: 2349. C# 14 - (4) 문자열 리터럴을 utf-8 인코딩으로 저장파일 다운로드1
13976정성태7/25/20251874닷넷: 2348. C# - 카카오 카나나 모델 + Microsoft.ML.OnnxRuntimeGenAI 예제파일 다운로드1
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...