Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)

윈도우 8에서 Hyper-V 유무에 따른 듀얼 부트 설정하는 방법

Hyper-V가 설치된 PC에서 wacom 태블릿을 사용하니 은근히 부하가 있습니다. 아래는 wacom 태블릿이 연결된 상태에서 펜을 태블릿 위에 올려 놓은 상태로만 있었을 때의 CPU 소비 현황입니다.

wacom_cpu_consume_1.png

보시는 바와 같이 아무것도 하지 않아도 CPU가 항상 4 ~ 5%를 소비합니다. 또한, 시스템을 사용하면서 점점 더 UI 반응 속도가 늦어짐을 체감할 수 있습니다. 그래서 자주 껏다 켜야 합니다.

그렇다고 Hyper-V를 제거하자니 가끔 사용하게 되는 Virtual Machine이 아쉽고 필요할 때마다 다시 설치하자니 재부팅이 너무 비효율적입니다. (아시다시피, Hyper-V 설치할 때 재부팅한번이 필요하고, 제거할 때도 재부팅이 필요합니다.)

이런 상황에서 적절한 선택이라면, 아래의 글처럼 Hyper-visor만 비활성화시킨 부팅 모드를 하나 추가해주는 것이 될 수 있습니다.

Switch easily between VirtualBox and Hyper-V with a BCDEdit boot Entry in Windows 8.1
; http://www.hanselman.com/blog/SwitchEasilyBetweenVirtualBoxAndHyperVWithABCDEditBootEntryInWindows81.aspx

그리하여, 관리자 권한으로 실행한 명령행에서 bcdedit.exe를 이용해 부팅 모드를 하나 추가하고,

C:\>bcdedit /copy {current} /d "No Hyper-V" 
The entry was successfully copied to {ff-23-113-824e-5c5144ea}. 

출력된 유일값(위의 예제의 경우 "{ff-23-113-824e-5c5144ea}")을 그대로 복사해서 해당 부트 모드의 Hypervisor 기능을 꺼줍니다.

C:\>bcdedit /set {ff-23-113-824e-5c5144ea} hypervisorlaunchtype off 
The operation completed successfully.

이제부터는 재부팅이 될 때마다 다음 화면과 같이 부팅 모드를 선택하는 창이 한번 더 뜨게 됩니다.

[그림 출처: Switch easily between VirtualBox and Hyper-V with a BCDEdit boot Entry in Windows 8.1]
wacom_cpu_consume_2.jpg

이때 이전에 생성해 둔 "No Hyper-V" 항목을 선택해 주면 Hypervisor가 비활성화된 윈도우 운영체제가 올라오게 됩니다.

게다가 "Switch easily between VirtualBox and Hyper-V with a BCDEdit boot Entry in Windows 8.1" 글에서 알 수 있듯이, 이 상태의 부팅 모드에서는 VirtualBox 같은 가상화 프로그램도 설치할 수 있으니 괜찮은 선택이 될 수 있겠습니다.




Hypervisor가 없는 윈도우 운영체제에서도 Wacom 태블릿의 펜을 태블릿위에 감지되는 상태로 두면 3%의 CPU가 유지되는 것을 볼 수 있습니다. 그래도 UI 반응성은 Hypervisor가 있을 때와는 확연한 차이로 빠릅니다.

제 판단으로는, Wacom 태블릿과 Hyper-V를 함께 쓰는 것은 성능상 권장되지 않습니다. 어쨌든 wacom 때문에 고생 좀 하게 되는군요.

WACOM 태블릿 환경에서 WinForm 실행시 System.ArgumentException 예외 발생
; https://www.sysnet.pe.kr/2/0/1673

Wacom BAMBOO 태블릿 - 클릭이 더블 클릭으로 처리되는 문제
; https://www.sysnet.pe.kr/0/0/470

Wacom BAMBOO 태블릿 - 우클릭이 안되거나 좌표가 어긋나는 문제
; https://www.sysnet.pe.kr/0/0/472

그래도... 태블릿이 마우스보다는 편하기 때문에! ^^




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 7/10/2021]

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

비밀번호

댓글 작성자
 



2016-02-29 01시34분
bcdedit /set {current} description "No-HyperV"

bcdedit (Boot Configuration Data Editor)
정성태

... 61  62  63  64  65  66  67  68  69  70  71  72  [73]  74  75  ...
NoWriterDateCnt.TitleFile(s)
12111정성태1/12/202020563디버깅 기술: 155. C# - KernelMemoryIO 드라이버를 이용해 실행 프로그램을 숨기는 방법(DKOM: Direct Kernel Object Modification) [16]파일 다운로드1
12110정성태1/11/202019892디버깅 기술: 154. Patch Guard로 인해 블루 스크린(BSOD)가 발생하는 사례 [5]파일 다운로드1
12109정성태1/10/202016600오류 유형: 588. Driver 프로젝트 빌드 오류 - Inf2Cat error -2: "Inf2Cat, signability test failed."
12108정성태1/10/202017431오류 유형: 587. Kernel Driver 시작 시 127(The specified procedure could not be found.) 오류 메시지 발생
12107정성태1/10/202018622.NET Framework: 877. C# - 프로세스의 모든 핸들을 열람 - 두 번째 이야기
12106정성태1/8/202019654VC++: 136. C++ - OSR Driver Loader와 같은 Legacy 커널 드라이버 설치 프로그램 제작 [1]
12105정성태1/8/202018149디버깅 기술: 153. C# - PEB를 조작해 로드된 DLL을 숨기는 방법
12104정성태1/7/202019374DDK: 9. 커널 메모리를 읽고 쓰는 NT Legacy driver와 C# 클라이언트 프로그램 [4]
12103정성태1/7/202022511DDK: 8. Visual Studio 2019 + WDK Legacy Driver 제작- Hello World 예제 [1]파일 다운로드2
12102정성태1/6/202018830디버깅 기술: 152. User 권한(Ring 3)의 프로그램에서 _ETHREAD 주소(및 커널 메모리를 읽을 수 있다면 _EPROCESS 주소) 구하는 방법
12101정성태1/5/202019119.NET Framework: 876. C# - PEB(Process Environment Block)를 통해 로드된 모듈 목록 열람
12100정성태1/3/202016578.NET Framework: 875. .NET 3.5 이하에서 IntPtr.Add 사용
12099정성태1/3/202019447디버깅 기술: 151. Windows 10 - Process Explorer로 확인한 Handle 정보를 windbg에서 조회 [1]
12098정성태1/2/202019199.NET Framework: 874. C# - 커널 구조체의 Offset 값을 하드 코딩하지 않고 사용하는 방법 [3]
12097정성태1/2/202017272디버깅 기술: 150. windbg - Wow64, x86, x64에서의 커널 구조체(예: TEB) 구조체 확인
12096정성태12/30/201919912디버깅 기술: 149. C# - DbgEng.dll을 이용한 간단한 디버거 제작 [1]
12095정성태12/27/201921636VC++: 135. C++ - string_view의 동작 방식
12094정성태12/26/201919366.NET Framework: 873. C# - 코드를 통해 PDB 심벌 파일 다운로드 방법
12093정성태12/26/201918948.NET Framework: 872. C# - 로딩된 Native DLL의 export 함수 목록 출력파일 다운로드1
12092정성태12/25/201917679디버깅 기술: 148. cdb.exe를 이용해 (ntdll.dll 등에 정의된) 커널 구조체 출력하는 방법
12091정성태12/25/201919999디버깅 기술: 147. pdb 파일을 다운로드하기 위한 symchk.exe 실행에 필요한 최소 파일 [1]
12090정성태12/24/201920111.NET Framework: 871. .NET AnyCPU로 빌드된 PE 헤더의 로딩 전/후 차이점 [1]파일 다운로드1
12089정성태12/23/201919057디버깅 기술: 146. gflags와 _CrtIsMemoryBlock을 이용한 Heap 메모리 손상 여부 체크
12088정성태12/23/201918003Linux: 28. Linux - 윈도우의 "Run as different user" 기능을 shell에서 실행하는 방법
12087정성태12/21/201918472디버깅 기술: 145. windbg/sos - Dictionary의 entries 배열 내용을 모두 덤프하는 방법 (do_hashtable.py) [1]
12086정성태12/20/201921019디버깅 기술: 144. windbg - Marshal.FreeHGlobal에서 발생한 덤프 분석 사례
... 61  62  63  64  65  66  67  68  69  70  71  72  [73]  74  75  ...