Microsoft MVP성태의 닷넷 이야기
개발 환경 구성: 38. Hyper-V 사용 후기 [링크 복사], [링크+제목 복사],
조회: 43900
글쓴 사람
정성태 (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분
정성태

... 16  17  18  19  20  [21]  22  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
13115정성태8/3/20228518.NET Framework: 2040. C# - ValueTask와 Task의 성능 비교 [1]파일 다운로드1
13114정성태8/2/20228711.NET Framework: 2039. C# - Task와 비교해 본 ValueTask 사용법파일 다운로드1
13113정성태7/31/20227981.NET Framework: 2038. C# 11 - Span 타입에 대한 패턴 매칭 (Pattern matching on ReadOnlySpan<char>)
13112정성태7/30/20228368.NET Framework: 2037. C# 11 - 목록 패턴(List patterns) [1]파일 다운로드1
13111정성태7/29/20228112.NET Framework: 2036. C# 11 - IntPtr/UIntPtr과 nint/nuint의 통합파일 다운로드1
13110정성태7/27/20228159.NET Framework: 2035. C# 11 - 새로운 연산자 ">>>" (Unsigned Right Shift)파일 다운로드1
13109정성태7/27/20229629VS.NET IDE: 177. 비주얼 스튜디오 2022를 이용한 (소스 코드가 없는) 닷넷 모듈 디버깅 - "외부 원본(External Sources)" [1]
13108정성태7/26/20227558Linux: 53. container에 실행 중인 Golang 프로세스를 디버깅하는 방법 [1]
13107정성태7/25/20226749Linux: 52. Debian/Ubuntu 계열의 docker container에서 자주 설치하게 되는 명령어
13106정성태7/24/20226471오류 유형: 819. 닷넷 6 프로젝트의 "Conditional compilation symbols" 기본값 오류
13105정성태7/23/20227750.NET Framework: 2034. .NET Core/5+ 환경에서 (프로젝트가 아닌) C# 코드 파일을 입력으로 컴파일하는 방법 - 두 번째 이야기 [1]
13104정성태7/23/202210852Linux: 51. WSL - init에서 systemd로 전환하는 방법
13103정성태7/22/20227367오류 유형: 818. WSL - systemd-genie와 관련한 2가지(systemd-remount-fs.service, multipathd.socket) 에러
13102정성태7/19/20226782.NET Framework: 2033. .NET Core/5+에서는 구할 수 없는 HttpRuntime.AppDomainAppId
13101정성태7/15/202215707도서: 시작하세요! C# 10 프로그래밍
13100정성태7/15/20228195.NET Framework: 2032. C# 11 - shift 연산자 재정의에 대한 제약 완화 (Relaxing Shift Operator)
13099정성태7/14/20228078.NET Framework: 2031. C# 11 - 사용자 정의 checked 연산자파일 다운로드1
13098정성태7/13/20226262개발 환경 구성: 647. Azure - scale-out 상태의 App Service에서 특정 인스턴스에 요청을 보내는 방법 [1]
13097정성태7/12/20225657오류 유형: 817. Golang - binary.Read: invalid type int32
13096정성태7/8/20228571.NET Framework: 2030. C# 11 - UTF-8 문자열 리터럴
13095정성태7/7/20226601Windows: 208. AD 도메인에 참여하지 않은 컴퓨터에서 Kerberos 인증을 사용하는 방법
13094정성태7/6/20226365오류 유형: 816. Golang - "short write" 오류 원인
13093정성태7/5/20227271.NET Framework: 2029. C# - HttpWebRequest로 localhost 접속 시 2초 이상 지연
13092정성태7/3/20228258.NET Framework: 2028. C# - HttpWebRequest의 POST 동작 방식파일 다운로드1
13091정성태7/3/20227086.NET Framework: 2027. C# - IPv4, IPv6를 모두 지원하는 서버 소켓 생성 방법
13090정성태6/29/20226203오류 유형: 815. PyPI에 업로드한 패키지가 반영이 안 되는 경우
... 16  17  18  19  20  [21]  22  23  24  25  26  27  28  29  30  ...