Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 84. Hyper-V의 네트워크 유형 (2) [링크 복사], [링크+제목 복사]
조회: 27931
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
Hyper-V의 네트워크 유형 (2)

자, 이번에도 Hyper-V의 네트워크 유형을 개선해 보기로 하겠습니다.

Hyper-V의 네트워크 유형 (1)
; https://www.sysnet.pe.kr/2/0/910

제가 원하는 유형은, 호스트 PC의 네트워크를 어지럽히지 않으면서 - 즉 별도의 네트워크로 분리되면서 호스트 및 인터넷 접속이 가능한 유형입니다.

"Windows Virtual PC"의 경우에는 이를 해결하기 위해 "Shared Networking (NAT) + Internal Network"를 사용하는 방법"Loopback Adapter + Internet Connection Sharing" 방법을 소개했었는데요.

Hyper-V의 경우에는 이 과정이 "Internal + Internet Connection Sharing" 방법으로 간단하게 해결됩니다.

"Windows Virtual PC"에서 제공되는 "Internal Network" 유형과는 다르게, Hyper-V의 "Internal"은 기본적으로 호스트 측에 가상 어댑터를 하나 생성시켜 주기 때문에 "VM <-> VM"과 "VM <-> HOST" 통신이 제공됩니다. 이 상태에서 단지 인터넷만 허용하도록 바꾸면 되기 때문에 공용망에 접속 가능한 어댑터에 ICS(Internet Connection Sharing) 기능을 "Internal"로 허용해주면 됩니다.

이렇게 되면, "Internal"의 네트워크가 "169.254.0.0"이던 것이 ICS의 영향으로 인해 "192.168.137.0"으로 바뀌게 됩니다. 아래는 ICS가 적용된 Internal 유형의 네트워크에 참여하고 있는 VM에 할당된 IP를 보여줍니다.

=== A VM ===
IP Address: 192.168.137.144
Subnet Mask: 255.255.255.0
Default Gateway: 192.168.137.1

보시는 것처럼, 내부망으로 분리되었고 ICS가 적용된 게이트웨이 덕분에 외부망까지 연결이 가능합니다. "Windows Virtual PC" 상황과 비교해 보면, Loopback 어댑터를 설치해야만 가능했던 설정이었습니다.

[정리: 가능한 접근 방식]
  • VM <-> VM
  • VM <-> HOST
  • VM -> 인터넷
  • VM -> HOST가 참여하고 있는 네트워크의 다른 PC





여기서 끝내기 아까우니 ^^...
지난번에, 서로 다른 Internal 네트워크에 참여하고 있는 PC끼리는 같은 B Class의 IP 대역이면서도 통신이 안된다고 했습니다.

이를 개선하려면, 해당 Internal 네트워크 간에 Bridge 연결을 구성해 주면 됩니다.

예를 들어, 다음과 같이 2개의 "Internal" 네트워크가 있다면 모두 선택하고 마우스 오른쪽 버튼을 눌러 나오는 메뉴의 "Bridge Connections"를 선택합니다.

bridge_internal_1.png

그럼, 다음과 같이 선택된 인터페이스 카드 간에 "Bridge"를 연결해 줍니다.

bridge_internal_2.png

물리적으로 비유를 해본다면, 2개의 네트워크 간에 스위치 허브로 연결해 주었다고 보시면 됩니다. 이 때문에, 원래 "Internal" 네트워크 간에는 통신이 안되었는데 위와 같이 브릿지를 설정한 이후에는 2개의 네트워크 간에 통신이 가능합니다.

이렇게 Bridge를 연결함으로 인해 한 가지 더 좋은 점이 있다면!

ICS의 한 가지 제약이 바로 인터넷 공유를 가능하게 해주는 대상 인터페이스가 "한 개"로 제한된다는 점입니다. 이로 인해 "Internal" 유형이 2개라면 그중의 하나만을 선택해서 외부망 통신이 가능하게 할 수 있습니다.

그런 경우에도, 2개의 Internal 네트워크를 Bridge로 연결해 주고, 그 Bridge에 대해서 ICS로 지정해 주는 방법이 있습니다.

bridge_internal_3.png

물론, 이런 경우에는 ICS 때문에 네트워크 대역이 바뀌는데요. 실제로 각각의 네트워크에 있는 VM에 할당된 IP를 보면,

=== InternalNetwork: A VM ===
IP Address: 192.168.137.146
Subnet Mask: 255.255.255.0
Default Gateway: 192.168.137.1

=== InternalNetwork2: B VM ===
IP Address: 192.168.137.148
Subnet Mask: 255.255.255.0
Default Gateway: 192.168.137.1

ICS의 영향으로 모두 192.168.137.0 네트워크에 참여했고 게이트웨이도 같습니다.

[정리: 가능한 접근 방식]
  • VM <-> VM
  • VM <-> HOST
  • VM <-> 같은 Bridge의 다른 어댑터들이 참여하고 있는 네트워크의 PC
  • VM -> 인터넷
  • VM -> HOST가 참여하고 있는 네트워크의 다른 PC





브릿지 관련해서 옛 이야기 하나 하자면,

무선 액세스 포인트를 구입해서 사용하기 전에는, 실제로 물리 PC 한 대를 무선 AP처럼 인터넷 라인에 물려놓고 네트워크 카드를 여러 개 꽂아서 스위치처럼 사용한 적이 있습니다. 그럴 때, 다른 컴퓨터와 연결되는 네트워크 카드가 2장 이상일 때는 위의 브릿지 기능을 이용해서 인터넷을 전체적으로 사용하도록 설정을 했었지요.

그런 경우, 스위치처럼 사용하는 그 물리 PC가 다운되면 전체 PC들의 인터넷이 안되는 부작용이 있었지만, 나름 한동안 잘 써먹었습니다. 이제는... ^^ 워낙 좋은 무선 AP들이 싼 값에 보급되다 보니 그럴 일이 없어졌지만.



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

[연관 글]


donaricano-btn



[최초 등록일: ]
[최종 수정일: 6/26/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)
12936정성태1/22/202229.NET Framework: 1138. C# - ffmpeg(FFmpeg.AutoGen)를 이용해 멀티미디어 파일의 메타데이터를 보여주는 예제(metadata.c)파일 다운로드1
12935정성태1/22/202226.NET Framework: 1137. ffmpeg의 파일 해시 예제(ffhash.c)를 C#으로 포팅파일 다운로드1
12934정성태1/22/202215오류 유형: 788. Warning C6262 Function uses '65564' bytes of stack: exceeds /analyze:stacksize '16384'. Consider moving some data to heap.
12933정성태1/21/202230.NET Framework: 1136. C# - ffmpeg(FFmpeg.AutoGen)를 이용해 MP2 오디오 파일 디코딩 예제(decode_audio.c)파일 다운로드1
12932정성태1/20/202276.NET Framework: 1135. C# - ffmpeg(FFmpeg.AutoGen)로 하드웨어 가속기를 이용한 비디오 디코딩 예제(hw_decode.c) [2]파일 다운로드1
12931정성태1/20/202274개발 환경 구성: 632. ASP.NET Core 프로젝트를 AKS/k8s에 올리는 과정
12930정성태1/19/202235개발 환경 구성: 631. AKS/k8s의 Volume에 파일 복사하는 방법
12929정성태1/19/202256개발 환경 구성: 630. AKS/k8s의 Pod에 Volume 연결하는 방법
12928정성태1/18/202251개발 환경 구성: 629. AKS/Kubernetes에서 호스팅 중인 pod에 shell(/bin/bash)로 진입하는 방법
12927정성태1/18/202260개발 환경 구성: 628. AKS 환경에 응용 프로그램 배포 방법
12926정성태1/17/202230오류 유형: 787. AKS - pod 배포 시 ErrImagePull/ImagePullBackOff 오류
12925정성태1/17/202271개발 환경 구성: 627. AKS의 준비 단계 - ACR(Azure Container Registry)에 docker 이미지 배포
12924정성태1/15/2022151.NET Framework: 1134. C# - ffmpeg(FFmpeg.AutoGen)를 이용한 비디오 디코딩 예제(decode_video.c) [2]파일 다운로드1
12923정성태1/15/202278개발 환경 구성: 626. ffmpeg.exe를 사용해 비디오 파일을 MPEG1 포맷으로 변경하는 방법
12922정성태1/14/202283개발 환경 구성: 625. AKS - Azure Kubernetes Service 생성 및 SLO/SLA 변경 방법
12921정성태1/14/202255개발 환경 구성: 624. Docker Desktop에서 별도 서버에 설치한 docker registry에 이미지 올리는 방법
12920정성태1/14/202223오류 유형: 786. Camtasia - An error occurred with the camera: Failed to Add Video Sampler.
12919정성태1/13/202280Windows: 199. Host Network Service (HNS)에 의해서 점유되는 포트
12918정성태1/13/202281Linux: 47. WSL - shell script에서 설정한 환경 변수가 스크립트 실행 후 반영되지 않는 문제
12917정성태1/12/202245오류 유형: 785. C# - The type or namespace name '...' could not be found (are you missing a using directive or an assembly reference?)
12916정성태1/12/202229오류 유형: 784. TFS - One or more source control bindings for this solution are not valid and are listed below.
12915정성태1/11/202260오류 유형: 783. Visual Studio - We didn't find any interpreters
12914정성태1/11/2022169VS.NET IDE: 172. 비주얼 스튜디오 2022의 파이선 개발 환경 지원
12913정성태1/11/2022136.NET Framework: 1133. C# - byte * (바이트 포인터)를 FileStream으로 쓰는 방법
12912정성태1/11/2022123개발 환경 구성: 623. ffmpeg.exe를 사용해 비디오 파일의 이미지를 PGM(Portable Gray Map) 파일 포맷으로 출력하는 방법
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...