Microsoft MVP성태의 닷넷 이야기
[개발 환경 구성] 개발 환경 구성: 36. Hyper-V 사용 후기 [링크 복사], [링크+제목 복사]
조회: 21842
글쓴 사람
정성태 (kevin13@chol.net)
홈페이지
첨부 파일
 

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 장치 인식 문제
; http://www.sysnet.pe.kr/Default.aspx?mode=2&sub=0&detail=1&wid=678

Virtual Machine Additions 제거
; http://www.sysnet.pe.kr/Default.aspx?mode=2&sub=0&detail=1&wid=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? 
; http://blogs.technet.com/jhoward/archive/2008/02/28/are-vhds-compatible-between-hyper-v-and-virtual-server-and-virtual-pc.aspx

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 사용율이 어쩌다 올라가는 사내 서버를 여러 대 사용하는 것은 전기 소비면에서나, 소음 관리면에서나 여러 모로 도움이 안되니!



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





[최초 등록일: ]
[최종 수정일: 4/3/2009 ]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:kevin13@chol.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)
11529정성태5/23/201874.NET : 601. 닷넷의 관리 포인터(Managed Pointer)와 System.TypedReference파일 다운로드1
11528정성태5/17/2018138.NET : 600. C# 7.2 - 3항 연산자에 ref 지원 [1]
11527정성태5/17/2018100오류 유형 : 463. RDP 로그인 에러 - This could be due to CredSSP encryption oracle remediation.
11526정성태5/16/2018111.NET : 599. C# 7.2 - 메서드의 반환값 및 로컬 변수에 ref readonly 기능 추가파일 다운로드1
11525정성태5/16/2018109.NET : 598. C# 7.2 - 메서드의 매개 변수에 in 변경자 추가파일 다운로드1
11524정성태5/15/2018142.NET : 597. C# 7.2 - readonly 구조체파일 다운로드1
11523정성태5/15/2018150.NET : 596. C# - 값 형식의 readonly 인스턴스에 대한 메서드 호출 시 defensive copy 발생 [1]파일 다운로드1
11522정성태5/15/2018106개발 환경 구성: 386. Azure - VM 진단 설정 화면의 "This subscription is not registered with the Microsoft.Insights resource provider."
11521정성태5/15/2018144개발 환경 구성: 385. Azure - 원하는 성능 데이터로 모니터링 대시보드 구성
11520정성태5/12/2018171.NET : 595. C# 7.1 - 참조 어셈블리(Ref Assemblies)
11519정성태5/12/2018202개발 환경 구성: 384. ASP.NET Web Application 프로젝트의 FileSystem 배포(Publish) 시 Before/After Task 설정 방법 [1]
11518정성태5/11/2018176.NET : 594. C# 7.0에서도 부분적으로 가능해진 "타입 추론을 통한 튜플의 변수명 자동 지정"
11517정성태5/10/2018186.NET : 593. Azure runbook 예제 - 6시간 동안 수행 중인 VM을 중지파일 다운로드1
11516정성태5/9/2018202.NET : 592. Azure runbook을 PowerShell 또는 C# 코드로 실행하는 방법파일 다운로드1
11515정성태5/9/2018257.NET : 591. C# 6 - Expression bodied function
11514정성태5/3/2018374오류 유형 : 462. Bitvise - Error in component session/transport/kexHandler [1]
11513정성태5/10/2018524.NET : 590. C# 언어의 공변성과 반공변성 [5]파일 다운로드1
11512정성태5/3/2018180개발 환경 구성: 383. Azure runbook 실행 시 "Errors", "All Logs"에 오류 메시지가 출력되는 경우
11511정성태5/2/2018257개발 환경 구성: 382. Azure - Runbook 기능 소개
11510정성태4/30/2018254.NET : 589. windbg로 확인하는 Finalizer를 가진 객체의 GC 과정파일 다운로드1
11509정성태4/28/2018298.NET : 588. windbg로 확인하는 객체의 GC 여부
11508정성태4/23/2018388개발 환경 구성: 381. MSBuild를 이용해 프로젝트 배포 후 결과물을 zip 파일로 압축하는 방법파일 다운로드1
11507정성태4/20/2018374개발 환경 구성: 380. MSBuild - 빌드 전/후, 배포 전/후 실행하고 싶은 Task 정의
11506정성태5/18/2018642.NET : 587. C#에서 enum을 boxing 없이 int로 변환하기 - 두 번째 이야기파일 다운로드1
11505정성태4/19/2018319개발 환경 구성: 379. Azure Web App 확장 예제 - Simple WebSite Extension
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...