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

비밀번호

댓글 작성자
 




... 166  167  168  169  170  171  172  173  174  175  176  177  [178]  179  180  ...
NoWriterDateCnt.TitleFile(s)
536정성태9/12/200732354.NET Framework: 97. WCF : netTcpBinding에서의 각종 Timeout 값 설명 [11]
535정성태9/11/200729810.NET Framework: 96. WCF - PerSession에서의 클라이언트 연결 관리 [5]
534정성태9/3/200725309개발 환경 구성: 29. VHD 파일 크기 줄이기
533정성태9/2/200728013개발 환경 구성: 28. CA 서비스 - 사용자 정의 템플릿 유형 추가
532정성태9/2/200730548개발 환경 구성: 27. AD CA에서 Code Signing 인증서 유형 추가 방법
531정성태9/2/200726286.NET Framework: 95. WCF에서의 DataTable 사용
530정성태9/1/200722779.NET Framework: 94. WCF 예외에 대한 시행착오
529정성태8/31/200725695.NET Framework: 93. WCF - DataContract와 KnownType 특성 [1]
528정성태8/30/200720348오류 유형: 47. VPC - 네트워크 어댑터 MAC 주소 중복 오류
527정성태8/30/200730427Team Foundation Server: 20. 잠긴 파일을 강제로 해제 [2]
526정성태8/29/200720323오류 유형: 46. VS.NET 2008 - ASP.NET 디버깅 : Strong name validation failed.
525정성태8/27/200722564VS.NET IDE: 54. VS.NET 2008 - 새롭게 도입되는 XSD Schema Designer
524정성태8/23/200740076오류 유형: 45. 요청한 작업은, 사용자가 매핑한 구역이 열려 있는...
523정성태8/16/200722716VS.NET IDE: 53. VS.NET 2008 - 서비스 참조 시 기존 데이터 컨테이너 DLL 사용
522정성태8/13/200726368VS.NET IDE: 52. VS.NET 2008 - WCF를 위한 디버깅 환경 개선
521정성태8/8/200726385.NET Framework: 92. XmlSerializer 생성자의 실행 속도를 올리는 방법 - 두 번째 이야기 [3]
520정성태8/7/200721586VS.NET IDE: 51. Visual Studio 2008 베타 2 설치
519정성태7/27/200727960오류 유형: 44. System.BadImageFormatException [2]
518정성태7/26/200728977오류 유형: 43. System.ComponentModel.LicenseException [1]
517정성태7/19/200717254개발 환경 구성: 26. VPC - 일반 사용자 계정으로 구동
516정성태7/19/200720379오류 유형: 42. TFS - Error loading menu: Index was outside the bounds of the array [2]
515정성태7/18/200728122오류 유형: 41. SSL 서버 자격 증명을 만드는 동안 심각한 오류가 발생했습니다.
514정성태7/14/200720815Team Foundation Server: 19. Orcas에서 개선되는 TFS 기능들
513정성태7/4/200731791.NET Framework: 91. Foreground Thread / Background Thread [1]
512정성태6/27/200721725오류 유형: 40. error PRJ0050: Failed to register output.
511정성태6/25/200729726.NET Framework: 90. XmlSerializer 생성자의 실행 속도를 올리는 방법 [2]
... 166  167  168  169  170  171  172  173  174  175  176  177  [178]  179  180  ...