Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)
(시리즈 글이 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와 고성능 그래픽 카드의 성능 문제 해결


Hyper-V가 설치된 PC에서는 고성능 그래픽 카드가 문제가 된다는 점을 이전 글에서도 몇 번 언급해 드렸지요.

Hyper-V 사용 후기 - 9. 호스트 운영체제의 반응 하락
; https://www.sysnet.pe.kr/2/0/685

Hyper-V 시스템에서의 표준 비디오 드라이버 설치 고려
; https://www.sysnet.pe.kr/2/1/1044

Hyper-V 시스템에서의 표준 비디오 드라이버 설치 고려 - 두 번째 이야기
; https://www.sysnet.pe.kr/2/1/1045

그런데, 오늘 드디어 희망적인 이야기가 "Virtual PC Guy"로부터 소개되었습니다.

Understanding High-End Video Performance Issues with Hyper-V
; http://blogs.msdn.com/virtual_pc_guy/archive/2009/11/16/understanding-high-end-video-performance-issues-with-hyper-v.aspx

일단 원인을 아주 상세하게 설명해 주고 있으며, 마지막에 4가지 해결책을 제시하고 있습니다.

  1. Use the default video driver (SVGA).
  2. Tone down the use of 3D graphics.
  3. Choose your video card carefully.
  4. Get a system with Second Level Address Translation (SLAT).

1번 방법은, 진짜 서버 환경으로 사용하는 상황에서 적절한 선택이겠고,
2번 방법은, 저처럼 3D 그래픽 환경을 그다지 구동할 일이 없는 사용자들에게 맞는 선택이고,
3번 방법은, 의미 없는 - 억지로 끼워놓은 ^^; 방법이겠고,
4번 방법이야말로 가장 현실성이 있으면서 확실한 해결 방법이 될 것 같습니다. 저 같은 경우, 집에 있는 컴퓨터는, Intel Quad-core 제품이라서 상관없는 이야기가 되었지만 어차피 시간이 지날수록 i7 CPU로 사용자들은 옮겨가게 될 테니 자연스럽게 해결될 수 있겠습니다.

실제로, 집에 있는 컴퓨터에서 3D 게임을 구동해 보고 성능 모니터로 "Virtual TLB Flush Entries/sec" 수치를 측정해 보면 아래와 같이 그래프가 엉망인 것을 볼 수 있습니다.

[그림 1: Intel Quad-Core Q9400에서 실행한 경우]
hyperv_with_highend_graphic_1.PNG

반면에 i7이 장착된 PC에서는 아래와 같이 ... 테스트를 잘못한 것이 아닌가 싶을 정도로 0만을 유지하고 있습니다.

[그림 2: Intel i7 920에서 실행한 경우]
hyperv_with_highend_graphic_2.PNG

i7 CPU 계열이 Hyper-V와 게임을 동시에 원하는 사용자들에게는 올바른 선택이 되겠습니다.



**** 내용 추가(2010-02-27) ****
Hyper-V and slow graphics?
; http://sphavens.com/2009/08/hyper-v-and-slow-graphics/

인텔: EPT (Extended Page Tables)
AMD: NPT(Nested Page Tables) or RVI(Rapid Virtualization Indexing)

문제는 EPT 기능이 지원되는 CPU가 명확하지 않다는 점입니다.
아래의 문서에 보면, EPT는 VT-x/i 기능 중의 하나로 분류되고 있습니다.

Intel Virtualization Technology
Roadmap and VT-d Support in Xen
; http://www.xen.org/files/xensummit_4/VT_roadmap_d_Nakajima.pdf

Virtual-PC Guy의 글에서도 나오지만 네할렘 구조를 채택한 CPU라고 말은 하면서도 i5에 대해서는 명확한 답변을 피하고 있습니다. 어쨌든 CPU 모델에 따라 기능 누락이 있을지는 모르겠지만, 아래의 문서에서도 확인되는 것처럼, 분명히 네할렘 구조의 CPU라면 (i3/i5/i7 모두!) EPT를 지원한다고는 되어 있습니다.

First the Tick, Now the Tock: Next Generation Intel® Microarchitecture (Nehalem)
; http://www.intel.com/technology/architecture-silicon/next-gen/whitepaper.pdf





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

[연관 글]






[최초 등록일: ]
[최종 수정일: 6/27/2021]

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

비밀번호

댓글 작성자
 



2022-04-05 10시11분
정성태

1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13565정성태2/23/20241691닷넷: 2219. .NET CLR2 보안 모델에서의 개별 System.Security.Permissions 제어
13564정성태2/22/20241939Windows: 259. Hyper-V Generation 1 유형의 VM을 Generation 2 유형으로 바꾸는 방법
13563정성태2/21/20241959디버깅 기술: 196. windbg - async/await 비동기인 경우 메모리 덤프 분석의 어려움
13562정성태2/21/20241988오류 유형: 896. ASP.NET - .NET Framework 기본 예제에서 System.Web에 대한 System.IO.FileNotFoundException 예외 발생
13561정성태2/20/20242071닷넷: 2218. C# - (예를 들어, Socket) 비동기 I/O에 대한 await 호출 시 CancellationToken을 이용한 취소파일 다운로드1
13560정성태2/19/20242114디버깅 기술: 195. windbg 분석 사례 - Semaphore 잠금으로 인한 Hang 현상 (닷넷)
13559정성태2/19/20242946오류 유형: 895. ASP.NET - System.Security.SecurityException: 'Requested registry access is not allowed.'
13558정성태2/18/20242190닷넷: 2217. C# - 최댓값이 1인 SemaphoreSlim 보다 Mutex 또는 lock(obj)를 선택하는 것이 나은 이유
13557정성태2/18/20241923Windows: 258. Task Scheduler의 Author 속성 값을 변경하는 방법
13556정성태2/17/20241980Windows: 257. Windows - Symbolic (hard/soft) Link 및 Junction 차이점
13555정성태2/15/20242130닷넷: 2216. C# - SemaphoreSlim 사용 시 주의점
13554정성태2/15/20241864VS.NET IDE: 189. Visual Studio - 닷넷 소스코드 디컴파일 찾기가 안 될 때
13553정성태2/14/20241950닷넷: 2215. windbg - thin/fat lock 없이 동작하는 Monitor.Wait + Pulse
13552정성태2/13/20241900닷넷: 2214. windbg - Monitor.Enter의 thin lock과 fat lock
13551정성태2/12/20242095닷넷: 2213. ASP.NET/Core 웹 응용 프로그램 - 2차 스레드의 예외로 인한 비정상 종료
13550정성태2/11/20242211Windows: 256. C# - Server socket이 닫히면 Accept 시켰던 자식 소켓이 닫힐까요?
13549정성태2/3/20242516개발 환경 구성: 706. C# - 컨테이너에서 실행하기 위한 (소켓) 콘솔 프로젝트 구성
13548정성태2/1/20242340개발 환경 구성: 705. "Docker Desktop for Windows" - ASP.NET Core 응용 프로그램의 소켓 주소 바인딩(IPv4/IPv6 loopback, Any)
13547정성태1/31/20242108개발 환경 구성: 704. Visual Studio - .NET 8 프로젝트부터 dockerfile에 추가된 "USER app" 설정
13546정성태1/30/20241976Windows: 255. (디버거의 영향 등으로) 대상 프로세스가 멈추면 Socket KeepAlive로 연결이 끊길까요?
13545정성태1/30/20241877닷넷: 2212. ASP.NET Core - 우선순위에 따른 HTTP/HTTPS 호스트:포트 바인딩 방법
13544정성태1/30/20241894오류 유형: 894. Microsoft.Data.SqlClient - Could not load file or assembly 'System.Security.Permissions, ...'
13543정성태1/30/20241924Windows: 254. Windows - 기본 사용 중인 5357 포트 비활성화는 방법
13542정성태1/30/20241920오류 유형: 893. Visual Studio - Web Application을 실행하지 못하는 IISExpress - 두 번째 이야기
13541정성태1/29/20241980VS.NET IDE: 188. launchSettings.json의 useSSL 옵션
13540정성태1/29/20242113Linux: 69. 리눅스 - "Docker Desktop for Windows" Container 환경에서 IPv6 Loopback Address 바인딩 오류
1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...