Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 38. Hyper-V 사용 후기 [링크 복사], [링크+제목 복사]
조회: 43788
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 3개 있습니다.)
(시리즈 글이 2개 있습니다.)
개발 환경 구성: 38. Hyper-V 사용 후기
; https://www.sysnet.pe.kr/2/0/685

개발 환경 구성: 55. Hyper-V와 고성능 그래픽 카드의 성능 문제 해결
; https://www.sysnet.pe.kr/2/0/801





Hyper-V 사용 후기


그동안 Virtual Server만을 사용해왔었는데요. 왜냐하면 기존의 "애슬론64-X2 맨체스터 3800+" CPU에서는 "가상화"지원을 하지 않았기 때문에 Hyper-V의 설치가 불가했었습니다. 마침, 이번에 PC를 업그레이드하면서 Hyper-V를 설치해보았는데요. 재미있군요. ^^




1. CPU의 가상화 지원 필수

이미 말씀드렸죠. CPU 차원에서의 가상화 지원은 필수입니다. 일례로 쿼드 코어 CPU라도 "코어2쿼드 요크필드Q8300"에서는 Hyper-V가 설치되지 않습니다.

2. 64비트 Windows Server 2008에서만 지원

32비트 Windows Server 2008에서는 Hyper-V가 설치되지 않습니다.

3. 가상 머신의 속도 향상

이 부분은 Virtual PC/Server에 비해 확실한 장점으로 작용합니다. 일례로, Virtual Server에서 Windows Vista 가상 머신을 구동시키면 속도가 너무 낮아서 ^^; 소프트웨어 테스트를 하려고 들어간 것인지? 인내심 테스트를 하려고 들어간 것인지... 때로는 헷갈릴 정도인데요. Hyper-V는 거의 Host OS의 속도로 Guest OS가 반응을 합니다. 심지어, 터미널 서비스로 접속해 보면 현재 환경이 Guest인지 Host인지 모를 정도입니다.

4. 가상 머신별로 분리된 프로세스

Virtual Server의 경우에는 단일 vssrvc.exe에서 모든 VPC가 구동이 되지만, Hyper-V의 경우에는 각각의 VM을 띄울 때마다 "vmwp.exe"라는 프로세스로 분리되어 "NETWORK SERVICE" 권한으로 실행됩니다.

5. 다중 CPU 할당

VMWare에서는 가능한 기능이었죠. Virtual Server에서는 가상 머신에 다중 코어를 할당할 수 없어서 아쉬운 부분이 있었는데 드디어 Hyper-V에 들어서면서 가능해졌습니다. 따라서 이제 가상 머신에서도 다중 스레드 응용 프로그램을 테스트할 수 있습니다.

6. 32비트/64비트 가상 머신 지원

역시 VMWare에서는 가능했었는데, Virtual Server에서는 없었던 기능입니다. Hyper-V에서는 32비트/64비트 가상 머신을 지원하고 역시 자유롭게 32비트/64비트 운영체제를 설치할 수 있습니다. CPU 할당과 지원 운영체제에 대한 보다 자세한 정보는 다음에서 확인할 수 있습니다.

Windows 2008 Hyper-V 지원 Guest OS List 
; http://blogs.technet.com/koreapartner/archive/2009/03/05/windows-2008-hyper-v-guest-os-list.aspx

7. 완벽한 VHD 포맷 호환

Virtual Server 또는 Virtual PC에서 사용 중이던 VHD 파일을 그대로 Hyper-V에 가져와서 가상 머신으로 운영하는 것이 가능합니다. VMWare 사용자라면 "VMDK to VHD Converter(무료)" 등의 응용 프로그램을 사용해서 우선 VHD로 변경한 다음 Hyper-V에 올리는 것이 가능합니다. 주의하실 사항이라면, 미리 가상 머신안에 설치된 "Virtual Machine Additions"를 삭제하고, Hyper-V에 올리시는 것이 좋습니다. 이와 관련해서는 다음의 토픽을 참조하십시오. (물론, Hyper-V에 올린 후 삭제하는 것도 가능하지만 여러 모로 불편하기 때문에 미리 삭제하는 것이 좋습니다.)

Hyper-V에서 Vista의 Virtual Machine Bus 장치 인식 문제
; https://www.sysnet.pe.kr/2/0/678

Virtual Machine Additions 제거
; https://www.sysnet.pe.kr/2/0/675

참고로, Hyper-V의 VHD와 Virtual PC/Server의 VHD는 상호 간에 호환이 되지만 주의하셔야 할 것은 일단 "Detect HAL"의 기능을 통해서 HAL이 바뀐 이후에는 Virtual PC/Server에서는 사용할 수 없습니다. (물론, VHD를 순수하게 드라이브 매핑으로 쓴다면 호환됩니다.)

Are VHDs compatible between Hyper-V and Virtual Server and Virtual PC? 
; https://learn.microsoft.com/en-us/archive/blogs/jhoward/are-vhds-compatible-between-hyper-v-and-virtual-server-and-virtual-pc

8. Virtual PC/Server와 Hyper-V 동시 사용 어려움

이 부분이 기존 Virtual PC/Server로부터 마이그레이션 하는 사용자들에게 힘든 부분인데요. 마이그레이션을 하려면 모든 VPC를 한번에 하시는 것이 좋습니다. 왜냐하면, Hyper-V가 설치된 환경에서 Virtual PC/Server를 이용하여 다시 VHD를 구동시키면 성능이 심각하게 하락됩니다. 제가 해본 바에 의하면, Virtual PC/Server에서 VPC가 하나 구동될 때마다 CPU 100%를 소비했습니다. (쿼드 코어인 경우, 25% 점유율을 꾸준히 나타냈습니다. 즉 VPC 4개 띄워놓으면 쿼드 코어의 CPU 점유율이 거의 항상 100%를 보인다는 것!)

이에 대한 설명으로, 마치 가상 머신 위에서 또 다른 가상 머신을 운영하는 것과 같은 이치라면서 성능 저하가 발생한다는 것입니다. 문제는, 이 성능 저하가 VPC 내에 국한된 것이 아니고, 호스트 PC까지도 영향을 준다는 것인데 따라서 행여나 2가지 가상화 기술을 병행해서 운영하려는 생각은 하지 않는 것이 좋겠습니다.

9. 호스트 운영체제의 반응 하락

혹시나 회사의 테스트 PC가 게임용이라면 ^^; Hyper-V 설치를 권장하고 싶지 않습니다. Hypervisor의 정확한 설계 구조를 논할 정도로 실력이 없기 때문에 근본적인 원인을 꼬집을 수는 없지만, Hypervisor 층이 운영체제 위가 아닌, 하드웨어의 바로 위에 위치하기 때문에 호스트 운영체제조차도 Hypercall을 통한 서비스 이용을 해야 하기 때문에 반응 속도가 하락하게 됩니다. 가상 머신의 반응 속도가 향상된 반면, 호스트 운영체제의 반응 속도는 떨어지는 결과를 낳은 것이지만, 실제 Hyper-V의 적용 대상이 서버 가상화 또는 테스트 환경 구성임을 감안할 때 호스트 운영체제의 성능하락은 그다지 중요한 문제는 아닙니다. 오히려 대다수의 호스트 운영체제는 서버 코어 버전으로 대체하는 것이 올바르다고 봐야 겠습니다.

10. 2가지 Hyper-V 설치 방법

이걸 주의하셔야 하는데요. ^^ "Hyper-V 서버"라는 것과 "Hyper-V 서비스"를 구별하셔야 합니다. 우선 "Hyper-V 서버"는 "Hyper-V 서비스"를 포함하면서 기본적으로 Windows Server 2008 Server-Core 유형으로 설치되는 것을 의미합니다. MSDN Subscription에서 다운로드할 수 있는 다음과 같은 제품이 바로 "Hyper-V 서버"입니다.

  • Applications - Hyper-V Server 2008 (x64) - DVD

또는 무료 다운로드가 가능한 아래의 제품도 바로 서버 코어 형식으로 기본 설치되는 유형입니다. (정확히 그 유형이 Windows Server 2008의 "서버 코어" 제품인지는 모르겠습니다.)

Microsoft Hyper-V Server 2008 - English
; http://www.microsoft.com/downloads/details.aspx?FamilyId=6067CB24-06CC-483A-AF92-B919F699C3A0&displaylang=en

이런 제품으로 설치하시면 다음과 같은 글에서 보는 것처럼 완전히 새로운 운영체제가 설치되고 콘솔창만이 뜨게 됩니다.

Introducing Microsoft Hyper-V Server 2008 - Part 1 : Installation
; http://www.elmajdal.net/Win2k8/Installing_Microsoft_Hyper_V_Server_2008.aspx

만약, 이미 Windows Server 2008이 설치된 상태라면 다음에서 설명하는 Hyper-V 서비스만을 올리시면 됩니다.

Hyper-V - Install & enable on Windows Server 2008 (64-bit)
; http://www.windowsreference.com/windows-server-2008/hyper-v-install-enable-on-windows-server-2008-64-bit/

참고로, 현재 Windows Server 2008에 포함된 Hyper-V 서비스는 RC1 버전인데 걱정할 필요 없이 설치하시고 Windows Update를 받으면 정식 버전으로 설치됩니다.




정리해 보면,

직접 개발자가 개발을 하는 컴퓨터가 아니라면 사내의 웬만한 컴퓨터는 Hyper-V를 통해서 통합하는 것을 충분히 고려해 봐도 좋을 것 같습니다. CPU 사용률이 어쩌다 올라가는 사내 서버를 여러 대 사용하는 것은 전기 소비면에서나, 소음 관리면에서나 여러 모로 도움이 안되니!



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

[연관 글]






[최초 등록일: ]
[최종 수정일: 6/16/2023]

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

비밀번호

댓글 작성자
 



2011-06-01 09시37분
정성태
2011-06-01 09시38분
C:\Windows\winsxs\amd64_microsoft-windows-defrag-cmdline_31bf3856ad364e35_6.1.7600.16385_none_2370c162e00680c3
정성태
2011-06-23 10시53분
How to install Clustered SQL Server 2008 on Windows 2008 Cluster using Hyper-V (Guest Clustering) Part ? 2
; http://blogs.msdn.com/b/sqlserverfaq/archive/2010/04/28/how-to-install-clustered-sql-server-2008-on-windows-2008-cluster-using-hyper-v-guest-clustering-part-2.aspx
정성태
2011-06-23 11시33분
정성태
2018-05-12 04시01분
정성태

1  2  3  4  5  6  7  8  9  10  11  12  [13]  14  15  ...
NoWriterDateCnt.TitleFile(s)
13294정성태3/22/20234122.NET Framework: 2105. LargeAddressAware 옵션이 적용된 닷넷 32비트 프로세스의 가용 메모리 - 두 번째
13293정성태3/22/20234191오류 유형: 853. dumpbin - warning LNK4048: Invalid format file; ignored
13292정성태3/21/20234305Windows: 232. C/C++ - 일반 창에도 사용 가능한 IsDialogMessage파일 다운로드1
13291정성태3/20/20234712.NET Framework: 2104. C# Windows Forms - WndProc 재정의와 IMessageFilter 사용 시의 차이점
13290정성태3/19/20234219.NET Framework: 2103. C# - 윈도우에서 기본 제공하는 FindText 대화창 사용법파일 다운로드1
13289정성태3/18/20233416Windows: 231. Win32 - 대화창 템플릿의 2진 리소스를 읽어들여 자식 윈도우를 생성하는 방법파일 다운로드1
13288정성태3/17/20233515Windows: 230. Win32 - 대화창의 DLU 단위를 pixel로 변경하는 방법파일 다운로드1
13287정성태3/16/20233683Windows: 229. Win32 - 대화창 템플릿의 2진 리소스를 읽어들여 윈도우를 직접 띄우는 방법파일 다운로드1
13286정성태3/15/20234146Windows: 228. Win32 - 리소스에 포함된 대화창 Template의 2진 코드 해석 방법
13285정성태3/14/20233736Windows: 227. Win32 C/C++ - Dialog Procedure를 재정의하는 방법파일 다운로드1
13284정성태3/13/20233936Windows: 226. Win32 C/C++ - Dialog에서 값을 반환하는 방법파일 다운로드1
13283정성태3/12/20233477오류 유형: 852. 파이썬 - TypeError: coercing to Unicode: need string or buffer, NoneType found
13282정성태3/12/20233807Linux: 58. WSL - nohup 옵션이 필요한 경우
13281정성태3/12/20233716Windows: 225. 윈도우 바탕화면의 아이콘들이 넓게 퍼지는 경우 [2]
13280정성태3/9/20234453개발 환경 구성: 670. WSL 2에서 호스팅 중인 TCP 서버를 외부에서 접근하는 방법
13279정성태3/9/20233996오류 유형: 851. 파이썬 ModuleNotFoundError: No module named '_cffi_backend'
13278정성태3/8/20233940개발 환경 구성: 669. WSL 2의 (init이 아닌) systemd 지원 [1]
13277정성태3/6/20234575개발 환경 구성: 668. 코드 사인용 인증서 신청 및 적용 방법(예: Digicert)
13276정성태3/5/20234306.NET Framework: 2102. C# 11 - ref struct/ref field를 위해 새롭게 도입된 scoped 예약어
13275정성태3/3/20234660.NET Framework: 2101. C# 11의 ref 필드 설명
13274정성태3/2/20234252.NET Framework: 2100. C# - ref 필드로 ref struct 타입을 허용하지 않는 이유
13273정성태2/28/20233953.NET Framework: 2099. C# - 관리 포인터로서의 ref 예약어 의미
13272정성태2/27/20234199오류 유형: 850. SSMS - mdf 파일을 Attach 시킬 때 Operating system error 5: "5(Access is denied.)" 에러
13271정성태2/25/20234142오류 유형: 849. Sql Server Configuration Manager가 시작 메뉴에 없는 경우
13270정성태2/24/20233754.NET Framework: 2098. dotnet build에 /p 옵션을 적용 시 유의점
13269정성태2/23/20234289스크립트: 46. 파이썬 - uvicorn의 콘솔 출력을 UDP로 전송
1  2  3  4  5  6  7  8  9  10  11  12  [13]  14  15  ...